!478 fix save_graphs_path and log file mode related issues

Merge pull request !478 from fary86/fix_log_and_ir_issues
This commit is contained in:
mindspore-ci-bot 2020-04-20 19:07:38 +08:00 committed by Gitee
commit 679dbd27b3
5 changed files with 67 additions and 8 deletions

View File

@ -179,7 +179,7 @@ void LogWriter::operator^(const LogStream &stream) const {
std::ostringstream oss; std::ostringstream oss;
oss << location_.file_ << ":" << location_.line_ << " " << location_.func_ << "] "; oss << location_.file_ << ":" << location_.line_ << " " << location_.func_ << "] ";
if (exception_type_ != NoExceptionType) { if (exception_type_ != NoExceptionType && exception_type_ != TypeError && exception_type_ != ValueError) {
oss << ExceptionTypeToString(exception_type_) << " "; oss << ExceptionTypeToString(exception_type_) << " ";
} }
oss << msg.str(); oss << msg.str();
@ -242,6 +242,10 @@ void mindspore_log_init(void) {
if (mindspore::GetEnv("GLOG_v").empty()) { if (mindspore::GetEnv("GLOG_v").empty()) {
FLAGS_v = mindspore::WARNING; FLAGS_v = mindspore::WARNING;
} }
// set default log file mode to 0640
if (mindspore::GetEnv("GLOG_logfile_mode").empty()) {
FLAGS_logfile_mode = 0640;
}
// default print log to screen // default print log to screen
if (mindspore::GetEnv("GLOG_logtostderr").empty()) { if (mindspore::GetEnv("GLOG_logtostderr").empty()) {
FLAGS_logtostderr = true; FLAGS_logtostderr = true;

View File

@ -16,6 +16,7 @@
The context of mindspore, used to configure the current execution environment, The context of mindspore, used to configure the current execution environment,
including execution mode, execution backend and other feature switchs. including execution mode, execution backend and other feature switchs.
""" """
import os
import threading import threading
from collections import namedtuple from collections import namedtuple
from types import FunctionType from types import FunctionType
@ -33,6 +34,31 @@ GRAPH_MODE = 0
PYNATIVE_MODE = 1 PYNATIVE_MODE = 1
def _make_directory(path: str):
"""Make directory."""
real_path = None
if path is None or not isinstance(path, str) or path.strip() == "":
raise ValueError(f"Input path `{path}` is invaild type")
# convert the relative paths
path = os.path.realpath(path)
logger.debug("The absolute path is %r", path)
# check whether the path is already existed and has written permissions
if os.path.exists(path):
real_path = path
else:
# All exceptions need to be caught because create directory maybe have some limit(permissions)
logger.debug("The directory(%s) doesn't exist, will create it", path)
try:
os.makedirs(path)
real_path = path
except PermissionError as e:
logger.error(f"No write permission on the directory `{path}, error = {e}")
raise ValueError(f"No write permission on the directory `{path}`.")
return real_path
class _ThreadLocalInfo(threading.local): class _ThreadLocalInfo(threading.local):
""" """
Thread local Info used for store thread local attributes. Thread local Info used for store thread local attributes.
@ -173,7 +199,7 @@ class _Context:
@save_graphs_path.setter @save_graphs_path.setter
def save_graphs_path(self, save_graphs_path): def save_graphs_path(self, save_graphs_path):
self._context_handle.set_save_graphs_path(save_graphs_path) self._context_handle.set_save_graphs_path(_make_directory(save_graphs_path))
@property @property
def device_target(self): def device_target(self):

View File

@ -128,8 +128,8 @@ TEST_F(TestComposite, test_TupleSlice_arg_one_number) {
trace::ClearTraceStack(); trace::ClearTraceStack();
engine_->Run(tupleSliceGraphPtr, args_spec_list); engine_->Run(tupleSliceGraphPtr, args_spec_list);
FAIL() << "Excepted exception :Args type is wrong"; FAIL() << "Excepted exception :Args type is wrong";
} catch (std::runtime_error const &err) { } catch (pybind11::type_error const &err) {
ASSERT_TRUE(std::string(err.what()).find("TypeError") != std::string::npos); ASSERT_TRUE(true);
} catch (...) { } catch (...) {
FAIL() << "Excepted exception :Args type is wrong"; FAIL() << "Excepted exception :Args type is wrong";
} }

View File

@ -13,6 +13,7 @@
# limitations under the License. # limitations under the License.
# ============================================================================ # ============================================================================
""" test_backend """ """ test_backend """
import os
import numpy as np import numpy as np
import pytest import pytest
from mindspore.ops import operations as P from mindspore.ops import operations as P
@ -51,10 +52,11 @@ def test_vm_backend():
def test_vm_set_context(): def test_vm_set_context():
""" test_vm_set_context """ """ test_vm_set_context """
context.set_context(save_graphs=True, save_graphs_path="/home/mindspore", mode=context.GRAPH_MODE) context.set_context(save_graphs=True, save_graphs_path="mindspore_ir_path", mode=context.GRAPH_MODE)
assert context.get_context("save_graphs") assert context.get_context("save_graphs")
assert context.get_context("mode") == context.GRAPH_MODE assert context.get_context("mode") == context.GRAPH_MODE
assert context.get_context("save_graphs_path") == "/home/mindspore" assert os.path.exists("mindspore_ir_path")
assert context.get_context("save_graphs_path").find("mindspore_ir_path") > 0
context.set_context(mode=context.PYNATIVE_MODE) context.set_context(mode=context.PYNATIVE_MODE)
@args_type_check(v_str=str, v_int=int, v_tuple=tuple) @args_type_check(v_str=str, v_int=int, v_tuple=tuple)
@ -74,3 +76,15 @@ def test_args_type_check():
with pytest.raises(TypeError): with pytest.raises(TypeError):
check_input("name", 100, "age") check_input("name", 100, "age")
check_input("name", 100, (10, 10)) check_input("name", 100, (10, 10))
def teardown_module():
dirs = ['mindspore_ir_path']
for item in dirs:
item_name = './' + item
if not os.path.exists(item_name):
continue
if os.path.isdir(item_name):
os.rmdir(item_name)
elif os.path.isfile(item_name):
os.remove(item_name)

View File

@ -13,6 +13,7 @@
# limitations under the License. # limitations under the License.
# ============================================================================ # ============================================================================
""" test_context """ """ test_context """
import os
import pytest import pytest
from mindspore import context from mindspore import context
# pylint: disable=W0212 # pylint: disable=W0212
@ -74,11 +75,12 @@ def test_dump_target():
def test_set_context(): def test_set_context():
""" test_set_context """ """ test_set_context """
context.set_context(mode=context.GRAPH_MODE, device_target="Ascend", context.set_context(mode=context.GRAPH_MODE, device_target="Ascend",
device_id=0, save_graphs=True, save_graphs_path="/mindspore") device_id=0, save_graphs=True, save_graphs_path="mindspore_ir_path")
assert context.get_context("device_id") == 0 assert context.get_context("device_id") == 0
assert context.get_context("device_target") == "Ascend" assert context.get_context("device_target") == "Ascend"
assert context.get_context("save_graphs") assert context.get_context("save_graphs")
assert context.get_context("save_graphs_path") == "/mindspore" assert os.path.exists("mindspore_ir_path")
assert context.get_context("save_graphs_path").find("mindspore_ir_path") > 0
assert context.get_context("mode") == context.GRAPH_MODE assert context.get_context("mode") == context.GRAPH_MODE
context.set_context(mode=context.PYNATIVE_MODE) context.set_context(mode=context.PYNATIVE_MODE)
@ -87,3 +89,16 @@ def test_set_context():
with pytest.raises(ValueError): with pytest.raises(ValueError):
context.set_context(modex="ge") context.set_context(modex="ge")
def teardown_module():
dirs = ['mindspore_ir_path']
for item in dirs:
item_name = './' + item
if not os.path.exists(item_name):
continue
if os.path.isdir(item_name):
os.rmdir(item_name)
elif os.path.isfile(item_name):
os.remove(item_name)