Refs #24278 -- Allowed multi-line serializations in OperationWriter.
Changed OperationWriter to support multi-line serialized values with correct indentation.
This commit is contained in:
parent
2cf28b6921
commit
d597174bd4
|
@ -13,6 +13,8 @@ class SeparateDatabaseAndState(Operation):
|
||||||
that affect the state or not the database, or so on.
|
that affect the state or not the database, or so on.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
serialization_expand_args = ['database_operations', 'state_operations']
|
||||||
|
|
||||||
def __init__(self, database_operations=None, state_operations=None):
|
def __init__(self, database_operations=None, state_operations=None):
|
||||||
self.database_operations = database_operations or []
|
self.database_operations = database_operations or []
|
||||||
self.state_operations = state_operations or []
|
self.state_operations = state_operations or []
|
||||||
|
|
|
@ -39,11 +39,10 @@ class SettingsReference(str):
|
||||||
|
|
||||||
|
|
||||||
class OperationWriter(object):
|
class OperationWriter(object):
|
||||||
indentation = 2
|
def __init__(self, operation, indentation=2):
|
||||||
|
|
||||||
def __init__(self, operation):
|
|
||||||
self.operation = operation
|
self.operation = operation
|
||||||
self.buff = []
|
self.buff = []
|
||||||
|
self.indentation = indentation
|
||||||
|
|
||||||
def serialize(self):
|
def serialize(self):
|
||||||
|
|
||||||
|
@ -56,7 +55,14 @@ class OperationWriter(object):
|
||||||
for key, value in _arg_value.items():
|
for key, value in _arg_value.items():
|
||||||
key_string, key_imports = MigrationWriter.serialize(key)
|
key_string, key_imports = MigrationWriter.serialize(key)
|
||||||
arg_string, arg_imports = MigrationWriter.serialize(value)
|
arg_string, arg_imports = MigrationWriter.serialize(value)
|
||||||
self.feed('%s: %s,' % (key_string, arg_string))
|
args = arg_string.splitlines()
|
||||||
|
if len(args) > 1:
|
||||||
|
self.feed('%s: %s' % (key_string, args[0]))
|
||||||
|
for arg in args[1:-1]:
|
||||||
|
self.feed(arg)
|
||||||
|
self.feed('%s,' % args[-1])
|
||||||
|
else:
|
||||||
|
self.feed('%s: %s,' % (key_string, arg_string))
|
||||||
imports.update(key_imports)
|
imports.update(key_imports)
|
||||||
imports.update(arg_imports)
|
imports.update(arg_imports)
|
||||||
self.unindent()
|
self.unindent()
|
||||||
|
@ -66,13 +72,26 @@ class OperationWriter(object):
|
||||||
self.indent()
|
self.indent()
|
||||||
for item in _arg_value:
|
for item in _arg_value:
|
||||||
arg_string, arg_imports = MigrationWriter.serialize(item)
|
arg_string, arg_imports = MigrationWriter.serialize(item)
|
||||||
self.feed('%s,' % arg_string)
|
args = arg_string.splitlines()
|
||||||
|
if len(args) > 1:
|
||||||
|
for arg in args[:-1]:
|
||||||
|
self.feed(arg)
|
||||||
|
self.feed('%s,' % args[-1])
|
||||||
|
else:
|
||||||
|
self.feed('%s,' % arg_string)
|
||||||
imports.update(arg_imports)
|
imports.update(arg_imports)
|
||||||
self.unindent()
|
self.unindent()
|
||||||
self.feed('],')
|
self.feed('],')
|
||||||
else:
|
else:
|
||||||
arg_string, arg_imports = MigrationWriter.serialize(_arg_value)
|
arg_string, arg_imports = MigrationWriter.serialize(_arg_value)
|
||||||
self.feed('%s=%s,' % (_arg_name, arg_string))
|
args = arg_string.splitlines()
|
||||||
|
if len(args) > 1:
|
||||||
|
self.feed('%s=%s' % (_arg_name, args[0]))
|
||||||
|
for arg in args[1:-1]:
|
||||||
|
self.feed(arg)
|
||||||
|
self.feed('%s,' % args[-1])
|
||||||
|
else:
|
||||||
|
self.feed('%s=%s,' % (_arg_name, arg_string))
|
||||||
imports.update(arg_imports)
|
imports.update(arg_imports)
|
||||||
|
|
||||||
imports = set()
|
imports = set()
|
||||||
|
|
|
@ -37,9 +37,7 @@ class OperationWriterTests(SimpleTestCase):
|
||||||
|
|
||||||
def test_empty_signature(self):
|
def test_empty_signature(self):
|
||||||
operation = custom_migration_operations.operations.TestOperation()
|
operation = custom_migration_operations.operations.TestOperation()
|
||||||
writer = OperationWriter(operation)
|
buff, imports = OperationWriter(operation, indentation=0).serialize()
|
||||||
writer.indentation = 0
|
|
||||||
buff, imports = writer.serialize()
|
|
||||||
self.assertEqual(imports, {'import custom_migration_operations.operations'})
|
self.assertEqual(imports, {'import custom_migration_operations.operations'})
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
buff,
|
buff,
|
||||||
|
@ -49,9 +47,7 @@ class OperationWriterTests(SimpleTestCase):
|
||||||
|
|
||||||
def test_args_signature(self):
|
def test_args_signature(self):
|
||||||
operation = custom_migration_operations.operations.ArgsOperation(1, 2)
|
operation = custom_migration_operations.operations.ArgsOperation(1, 2)
|
||||||
writer = OperationWriter(operation)
|
buff, imports = OperationWriter(operation, indentation=0).serialize()
|
||||||
writer.indentation = 0
|
|
||||||
buff, imports = writer.serialize()
|
|
||||||
self.assertEqual(imports, {'import custom_migration_operations.operations'})
|
self.assertEqual(imports, {'import custom_migration_operations.operations'})
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
buff,
|
buff,
|
||||||
|
@ -63,9 +59,7 @@ class OperationWriterTests(SimpleTestCase):
|
||||||
|
|
||||||
def test_kwargs_signature(self):
|
def test_kwargs_signature(self):
|
||||||
operation = custom_migration_operations.operations.KwargsOperation(kwarg1=1)
|
operation = custom_migration_operations.operations.KwargsOperation(kwarg1=1)
|
||||||
writer = OperationWriter(operation)
|
buff, imports = OperationWriter(operation, indentation=0).serialize()
|
||||||
writer.indentation = 0
|
|
||||||
buff, imports = writer.serialize()
|
|
||||||
self.assertEqual(imports, {'import custom_migration_operations.operations'})
|
self.assertEqual(imports, {'import custom_migration_operations.operations'})
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
buff,
|
buff,
|
||||||
|
@ -76,9 +70,7 @@ class OperationWriterTests(SimpleTestCase):
|
||||||
|
|
||||||
def test_args_kwargs_signature(self):
|
def test_args_kwargs_signature(self):
|
||||||
operation = custom_migration_operations.operations.ArgsKwargsOperation(1, 2, kwarg2=4)
|
operation = custom_migration_operations.operations.ArgsKwargsOperation(1, 2, kwarg2=4)
|
||||||
writer = OperationWriter(operation)
|
buff, imports = OperationWriter(operation, indentation=0).serialize()
|
||||||
writer.indentation = 0
|
|
||||||
buff, imports = writer.serialize()
|
|
||||||
self.assertEqual(imports, {'import custom_migration_operations.operations'})
|
self.assertEqual(imports, {'import custom_migration_operations.operations'})
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
buff,
|
buff,
|
||||||
|
@ -89,11 +81,21 @@ class OperationWriterTests(SimpleTestCase):
|
||||||
'),'
|
'),'
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def test_multiline_args_signature(self):
|
||||||
|
operation = custom_migration_operations.operations.ArgsOperation("test\n arg1", "test\narg2")
|
||||||
|
buff, imports = OperationWriter(operation, indentation=0).serialize()
|
||||||
|
self.assertEqual(imports, {'import custom_migration_operations.operations'})
|
||||||
|
self.assertEqual(
|
||||||
|
buff,
|
||||||
|
"custom_migration_operations.operations.ArgsOperation(\n"
|
||||||
|
" arg1='test\\n arg1',\n"
|
||||||
|
" arg2='test\\narg2',\n"
|
||||||
|
"),"
|
||||||
|
)
|
||||||
|
|
||||||
def test_expand_args_signature(self):
|
def test_expand_args_signature(self):
|
||||||
operation = custom_migration_operations.operations.ExpandArgsOperation([1, 2])
|
operation = custom_migration_operations.operations.ExpandArgsOperation([1, 2])
|
||||||
writer = OperationWriter(operation)
|
buff, imports = OperationWriter(operation, indentation=0).serialize()
|
||||||
writer.indentation = 0
|
|
||||||
buff, imports = writer.serialize()
|
|
||||||
self.assertEqual(imports, {'import custom_migration_operations.operations'})
|
self.assertEqual(imports, {'import custom_migration_operations.operations'})
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
buff,
|
buff,
|
||||||
|
@ -159,6 +161,14 @@ class WriterTests(TestCase):
|
||||||
string, imports = MigrationWriter.serialize("foobar")
|
string, imports = MigrationWriter.serialize("foobar")
|
||||||
self.assertEqual(string, "'foobar'")
|
self.assertEqual(string, "'foobar'")
|
||||||
|
|
||||||
|
def test_serialize_multiline_strings(self):
|
||||||
|
self.assertSerializedEqual(b"foo\nbar")
|
||||||
|
string, imports = MigrationWriter.serialize(b"foo\nbar")
|
||||||
|
self.assertEqual(string, "b'foo\\nbar'")
|
||||||
|
self.assertSerializedEqual("föo\nbár")
|
||||||
|
string, imports = MigrationWriter.serialize("foo\nbar")
|
||||||
|
self.assertEqual(string, "'foo\\nbar'")
|
||||||
|
|
||||||
def test_serialize_collections(self):
|
def test_serialize_collections(self):
|
||||||
self.assertSerializedEqual({1: 2})
|
self.assertSerializedEqual({1: 2})
|
||||||
self.assertSerializedEqual(["a", 2, True, None])
|
self.assertSerializedEqual(["a", 2, True, None])
|
||||||
|
|
Loading…
Reference in New Issue