|
16 | 16 | QStyleOptionViewItem, QDialog, QMenu, QToolTip, QListView |
17 | 17 | from AnyQt.QtTest import QTest, QSignalSpy |
18 | 18 |
|
| 19 | +from orangewidget.settings import Context |
19 | 20 | from orangewidget.tests.utils import simulate |
20 | 21 |
|
21 | 22 | from Orange.data import ( |
@@ -408,6 +409,107 @@ def data(fr, to): |
408 | 409 | self.assertEqual([var.name for var in outp.domain.attributes], |
409 | 410 | ["v0", "v1", "v2", "xv3", "v4"]) |
410 | 411 |
|
| 412 | + def test_migrate_settings_hints_2_to_3(self): |
| 413 | + settings = { |
| 414 | + '__version__': 2, |
| 415 | + 'context_settings': |
| 416 | + [Context(values={ |
| 417 | + '_domain_change_store': ( |
| 418 | + {('Categorical', ('a', ('mir1', 'mir4', 'mir2'), (), False)): |
| 419 | + [('Rename', ('disease mir',))], |
| 420 | + ('Categorical', ('b', ('mir4', 'mir1', 'mir2'), (), False)): |
| 421 | + [('Rename', ('disease mirs',))] |
| 422 | + }, |
| 423 | + -2), |
| 424 | + '_merge_dialog_settings': ({}, -4), |
| 425 | + '_selected_item': (('1', 0), -2), |
| 426 | + 'output_table_name': ('boo', -2), |
| 427 | + '__version__': 2}), |
| 428 | + Context(values={ |
| 429 | + '_domain_change_store': ( |
| 430 | + {('Categorical', ('b', ('mir4', 'mir1', 'mir2'), (), False)): |
| 431 | + [('Rename', ('disease bmir',))], |
| 432 | + ('Categorical', ('c', ('mir4', 'mir1', 'mir2'), (), False)): |
| 433 | + [('Rename', ('disease mirs',))] |
| 434 | + }, |
| 435 | + -2), |
| 436 | + '_merge_dialog_settings': ({}, -4), |
| 437 | + '_selected_item': (('1', 0), -2), |
| 438 | + 'output_table_name': ('far', -2), |
| 439 | + '__version__': 2}), |
| 440 | + ]} |
| 441 | + migrated_hints = { |
| 442 | + ('Categorical', ('b', ('mir4', 'mir1', 'mir2'), (), False)): |
| 443 | + [('Rename', ('disease bmir',))], |
| 444 | + ('Categorical', ('c', ('mir4', 'mir1', 'mir2'), (), False)): |
| 445 | + [('Rename', ('disease mirs',))], |
| 446 | + ('Categorical', ('a', ('mir1', 'mir4', 'mir2'), (), False)): |
| 447 | + [('Rename', ('disease mir',))], |
| 448 | + } |
| 449 | + widget = self.create_widget(OWEditDomain, stored_settings=settings) |
| 450 | + self.assertEqual(widget._domain_change_hints, migrated_hints) |
| 451 | + # order matters |
| 452 | + self.assertEqual(list(widget._domain_change_hints), list(migrated_hints)) |
| 453 | + self.assertEqual(widget.output_table_name, "far") |
| 454 | + |
| 455 | + def test_migrate_settings_2_to_3_realworld(self): |
| 456 | + settings = { |
| 457 | + 'controlAreaVisible': True, |
| 458 | + '__version__': 2, |
| 459 | + 'context_settings': [Context( |
| 460 | + values={ |
| 461 | + '_domain_change_store': |
| 462 | + ({('Real', ('sepal length', (1, 'f'), (), False)): |
| 463 | + [('AsString', ())], |
| 464 | + ('Real', ('sepal width', (1, 'f'), (), False)): |
| 465 | + [('AsTime', ()), ('StrpTime', ('Detect automatically', None, 1, 1))], |
| 466 | + ('Real', ('petal width', (1, 'f'), (), False)): |
| 467 | + [('Annotate', ((('a', 'b'),),))]}, -2), |
| 468 | + '_merge_dialog_settings': ({}, -4), |
| 469 | + '_selected_item': (('petal width', 2), -2), |
| 470 | + 'output_table_name': ('', -2), |
| 471 | + '__version__': 2}, |
| 472 | + attributes={'sepal length': 2, 'sepal width': 2, |
| 473 | + 'petal length': 2, 'petal width': 2, 'iris': 1}, |
| 474 | + metas={} |
| 475 | + )] |
| 476 | + } |
| 477 | + widget = self.create_widget(OWEditDomain, stored_settings=settings) |
| 478 | + self.assertEqual( |
| 479 | + widget._domain_change_hints, |
| 480 | + {('Real', ('sepal length', (1, 'f'), (), False)): |
| 481 | + [('AsString', ())], |
| 482 | + ('Real', ('sepal width', (1, 'f'), (), False)): |
| 483 | + [('AsTime', ()), |
| 484 | + ('StrpTime', ('Detect automatically', None, 1, 1))], |
| 485 | + ('Real', ('petal width', (1, 'f'), (), False)): |
| 486 | + [('Annotate', ((('a', 'b'),),))]} |
| 487 | + ) |
| 488 | + |
| 489 | + def test_migrate_settings_name_2_to_3(self): |
| 490 | + settings = { |
| 491 | + '__version__': 2, |
| 492 | + 'context_settings': |
| 493 | + [Context(values={ |
| 494 | + '_domain_change_store': ({}, -2), |
| 495 | + 'output_table_name': ('boo', -2), |
| 496 | + '__version__': 2}), |
| 497 | + Context(values={ |
| 498 | + '_domain_change_store': ({}, -2), |
| 499 | + 'output_table_name': ('far', -2), |
| 500 | + '__version__': 2}), |
| 501 | + Context(values={ |
| 502 | + '_domain_change_store': ({}, -2), |
| 503 | + 'output_table_name': ('', -2), |
| 504 | + '__version__': 2}), |
| 505 | + Context(values={ |
| 506 | + '_domain_change_store': ({}, -2), |
| 507 | + '__version__': 2}) |
| 508 | + ] |
| 509 | + } |
| 510 | + widget = self.create_widget(OWEditDomain, stored_settings=settings) |
| 511 | + self.assertEqual(widget.output_table_name, "far") |
| 512 | + |
411 | 513 |
|
412 | 514 | class TestEditors(GuiTest): |
413 | 515 | def test_variable_editor(self): |
|
0 commit comments