def test_update_with_kwargs(self): nd = NormalizedDict({"a": 0, "c": 1}) nd.update({"b": 2, "c": 3}, b=4, d=5) for k, v in [("a", 0), ("b", 4), ("c", 3), ("d", 5)]: assert_equals(nd[k], v) assert_equals(nd[k.upper()], v) assert_true(k in nd) assert_true(k.upper() in nd) assert_true(k in nd.keys())
def test_update_with_kwargs(self): nd = NormalizedDict({'a': 0, 'c': 1}) nd.update({'b': 2, 'c': 3}, b=4, d=5) for k, v in [('a', 0), ('b', 4), ('c', 3), ('d', 5)]: assert_equal(nd[k], v) assert_equal(nd[k.upper()], v) assert_true(k in nd) assert_true(k.upper() in nd) assert_true(k in nd.keys())
def test_update_with_kwargs(self): nd = NormalizedDict({'a': 0, 'c': 1}) nd.update({'b': 2, 'c': 3}, b=4, d=5) for k, v in [('a', 0), ('b', 4), ('c', 3), ('d', 5)]: assert_equals(nd[k], v) assert_equals(nd[k.upper()], v) assert_true(k in nd) assert_true(k.upper() in nd) assert_true(k in nd.keys())
def test_update_using_another_norm_dict(self): nd = NormalizedDict({'a': 1, 'b': 1}) nd.update(NormalizedDict({'B': 2, 'C': 2})) for c in 'bc': assert_equals(nd[c], 2) assert_equals(nd[c.upper()], 2) assert_true('b' in nd.keys()) assert_true('B' not in nd.keys()) assert_true('c' not in nd.keys()) assert_true('C' in nd.keys())
def test_update_using_another_norm_dict(self): nd = NormalizedDict({"a": 1, "b": 1}) nd.update(NormalizedDict({"B": 2, "C": 2})) for c in "bc": assert_equals(nd[c], 2) assert_equals(nd[c.upper()], 2) assert_true("b" in nd.keys()) assert_true("B" not in nd.keys()) assert_true("c" not in nd.keys()) assert_true("C" in nd.keys())
def test_update(self): nd = NormalizedDict({'a': 1, 'b': 1, 'c': 1}) nd.update({'b': 2, 'C': 2, 'D': 2}) for c in 'bcd': assert_equals(nd[c], 2) assert_equals(nd[c.upper()], 2) assert_true('b' in nd.keys()) assert_true('c' in nd.keys()) assert_true('C' not in nd.keys()) assert_true('d' not in nd.keys()) assert_true('D' in nd.keys())
def test_update(self): nd = NormalizedDict({"a": 1, "b": 1, "c": 1}) nd.update({"b": 2, "C": 2, "D": 2}) for c in "bcd": assert_equals(nd[c], 2) assert_equals(nd[c.upper()], 2) assert_true("b" in nd.keys()) assert_true("c" in nd.keys()) assert_true("C" not in nd.keys()) assert_true("d" not in nd.keys()) assert_true("D" in nd.keys())
class VariableStore(object): def __init__(self, variables): self.data = NormalizedDict(ignore='_') self._variables = variables def resolve_delayed(self): for name, value in self.data.items(): try: self._resolve_delayed(name, value) except DataError: pass def _resolve_delayed(self, name, value): if not isinstance(value, VariableTableValueBase): return value try: self.data[name] = value.resolve(self._variables) except DataError as err: # Recursive resolving may have already removed variable. if name in self: self.remove(name) value.report_error(err) raise_not_found('${%s}' % name, self.data, "Variable '${%s}' not found." % name) return self.data[name] def __getitem__(self, name): return self._resolve_delayed(name, self.data[name]) def update(self, store): self.data.update(store.data) def clear(self): self.data.clear() def add(self, name, value, overwrite=True, decorated=True): if decorated: name, value = self._undecorate(name, value) if overwrite or name not in self.data: self.data[name] = value def _undecorate(self, name, value): validate_var(name) if name[0] == '@': if not is_list_like(value): self._raise_cannot_set_type(name, value, 'list') value = list(value) if name[0] == '&': if not is_dict_like(value): self._raise_cannot_set_type(name, value, 'dictionary') value = DotDict(value) return name[2:-1], value def _raise_cannot_set_type(self, name, value, expected): raise DataError("Cannot set variable '%s': Expected %s-like value, " "got %s." % (name, expected, type_name(value))) def remove(self, name): if name in self.data: self.data.pop(name) def __len__(self): return len(self.data) def __iter__(self): return iter(self.data) def __contains__(self, name): return name in self.data def as_dict(self): variables = (self._decorate(name, self[name]) for name in self) return NormalizedDict(variables, ignore='_') def _decorate(self, name, value): if is_dict_like(value): name = '&{%s}' % name elif is_list_like(value): name = '@{%s}' % name else: name = '${%s}' % name return name, value
class VariableStore(object): def __init__(self, variables): self.data = NormalizedDict(ignore='_') self._variables = variables def resolve_delayed(self, item=None): if item: return self._resolve_delayed(*item) for name, value in list(self.data.items()): try: self._resolve_delayed(name, value) except DataError: pass def _resolve_delayed(self, name, value): if not self._is_resolvable(value): return value try: self.data[name] = value.resolve(self._variables) except DataError as err: # Recursive resolving may have already removed variable. if name in self: self.remove(name) value.report_error(err) variable_not_found('${%s}' % name, self.data, "Variable '${%s}' not found." % name) return self.data[name] def _is_resolvable(self, value): try: # isinstance can throw an exception in ironpython and jython return isinstance(value, VariableTableValueBase) except Exception: return False def __getitem__(self, name): return self._resolve_delayed(name, self.data[name]) def update(self, store): self.data.update(store.data) def clear(self): self.data.clear() def add(self, name, value, overwrite=True, decorated=True): if decorated: name, value = self._undecorate(name, value) if overwrite or name not in self.data: self.data[name] = value def _undecorate(self, name, value): validate_var(name) if name[0] == '@': if not is_list_like(value): self._raise_cannot_set_type(name, value, 'list') value = list(value) if name[0] == '&': if not is_dict_like(value): self._raise_cannot_set_type(name, value, 'dictionary') value = DotDict(value) return name[2:-1], value def _raise_cannot_set_type(self, name, value, expected): raise VariableError("Cannot set variable '%s': Expected %s-like value, " "got %s." % (name, expected, type_name(value))) def remove(self, name): if name in self.data: self.data.pop(name) def __len__(self): return len(self.data) def __iter__(self): return iter(self.data) def __contains__(self, name): return name in self.data def as_dict(self, decoration=True): if decoration: variables = (self._decorate(name, self[name]) for name in self) else: variables = self.data return NormalizedDict(variables, ignore='_') def _decorate(self, name, value): if is_dict_like(value): name = '&{%s}' % name elif is_list_like(value): name = '@{%s}' % name else: name = '${%s}' % name return name, value
class VariableStore: def __init__(self, variables): self.data = NormalizedDict(ignore='_') self._variables = variables def resolve_delayed(self, item=None): if item: return self._resolve_delayed(*item) for name, value in list(self.data.items()): try: self._resolve_delayed(name, value) except DataError: pass def _resolve_delayed(self, name, value): if not self._is_resolvable(value): return value try: self.data[name] = value.resolve(self._variables) except DataError as err: # Recursive resolving may have already removed variable. if name in self.data: self.data.pop(name) value.report_error(err) variable_not_found('${%s}' % name, self.data) return self.data[name] def _is_resolvable(self, value): try: return isinstance(value, Resolvable) except Exception: return False def __getitem__(self, name): if name not in self.data: variable_not_found('${%s}' % name, self.data) return self._resolve_delayed(name, self.data[name]) def get(self, name, default=NOT_SET, decorated=True): try: if decorated: name = self._undecorate(name) return self[name] except VariableError: if default is NOT_SET: raise return default def update(self, store): self.data.update(store.data) def clear(self): self.data.clear() def add(self, name, value, overwrite=True, decorated=True): if decorated: name, value = self._undecorate_and_validate(name, value) if (overwrite or name not in self.data or isinstance(self.data[name], GlobalVariableValue)): self.data[name] = value def _undecorate(self, name): if not is_assign(name): raise VariableError("Invalid variable name '%s'." % name) return name[2:-1] def _undecorate_and_validate(self, name, value): undecorated = self._undecorate(name) if name[0] == '@': if not is_list_like(value): self._raise_cannot_set_type(name, value, 'list') value = list(value) if name[0] == '&': if not is_dict_like(value): self._raise_cannot_set_type(name, value, 'dictionary') value = DotDict(value) return undecorated, value def _raise_cannot_set_type(self, name, value, expected): raise VariableError( "Cannot set variable '%s': Expected %s-like value, got %s." % (name, expected, type_name(value))) def __len__(self): return len(self.data) def __iter__(self): return iter(self.data) def __contains__(self, name): return name in self.data def as_dict(self, decoration=True): if decoration: variables = (self._decorate(name, self[name]) for name in self) else: variables = self.data return NormalizedDict(variables, ignore='_') def _decorate(self, name, value): if is_dict_like(value): name = '&{%s}' % name elif is_list_like(value): name = '@{%s}' % name else: name = '${%s}' % name return name, value