forked from mindspore-Ecosystem/mindspore
!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:
commit
679dbd27b3
|
@ -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;
|
||||||
|
|
|
@ -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):
|
||||||
|
|
|
@ -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";
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue