| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  | #  Copyright 2022 Collate | 
					
						
							| 
									
										
										
										
											2025-04-03 10:39:47 +05:30
										 |  |  | #  Licensed under the Collate Community License, Version 1.0 (the "License"); | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  | #  you may not use this file except in compliance with the License. | 
					
						
							|  |  |  | #  You may obtain a copy of the License at | 
					
						
							| 
									
										
										
										
											2025-04-03 10:39:47 +05:30
										 |  |  | #  https://github.com/open-metadata/OpenMetadata/blob/main/ingestion/LICENSE | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  | #  Unless required by applicable law or agreed to in writing, software | 
					
						
							|  |  |  | #  distributed under the License is distributed on an "AS IS" BASIS, | 
					
						
							|  |  |  | #  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
					
						
							|  |  |  | #  See the License for the specific language governing permissions and | 
					
						
							|  |  |  | #  limitations under the License. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | """
 | 
					
						
							|  |  |  | Test database connectors which extend from `CommonDbSourceService` with CLI | 
					
						
							|  |  |  | """
 | 
					
						
							| 
									
										
										
										
											2024-09-06 09:25:10 +02:00
										 |  |  | import os | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  | from abc import ABC, abstractmethod | 
					
						
							|  |  |  | from pathlib import Path | 
					
						
							| 
									
										
										
										
											2023-04-21 08:55:54 +02:00
										 |  |  | from typing import Optional | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | from sqlalchemy.engine import Engine | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-25 17:37:56 +02:00
										 |  |  | from metadata.config.common import load_config_file | 
					
						
							| 
									
										
										
										
											2024-09-06 09:25:10 +02:00
										 |  |  | from metadata.generated.schema.entity.services.databaseService import DatabaseService | 
					
						
							|  |  |  | from metadata.generated.schema.metadataIngestion.workflow import ( | 
					
						
							|  |  |  |     OpenMetadataWorkflowConfig, | 
					
						
							|  |  |  | ) | 
					
						
							| 
									
										
										
										
											2023-08-30 15:49:42 +02:00
										 |  |  | from metadata.ingestion.api.status import Status | 
					
						
							|  |  |  | from metadata.workflow.metadata import MetadataWorkflow | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-14 15:58:31 +02:00
										 |  |  | from ..base.test_cli import PATH_TO_RESOURCES | 
					
						
							|  |  |  | from ..base.test_cli_db import CliDBBase | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class CliCommonDB: | 
					
						
							|  |  |  |     class TestSuite(CliDBBase.TestSuite, ABC): | 
					
						
							|  |  |  |         engine: Engine | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         @classmethod | 
					
						
							|  |  |  |         def setUpClass(cls) -> None: | 
					
						
							|  |  |  |             connector = cls.get_connector_name() | 
					
						
							| 
									
										
										
										
											2023-08-30 15:49:42 +02:00
										 |  |  |             workflow: MetadataWorkflow = cls.get_workflow( | 
					
						
							|  |  |  |                 connector, cls.get_test_type() | 
					
						
							|  |  |  |             ) | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |             cls.engine = workflow.source.engine | 
					
						
							|  |  |  |             cls.openmetadata = workflow.source.metadata | 
					
						
							|  |  |  |             cls.config_file_path = str( | 
					
						
							|  |  |  |                 Path(PATH_TO_RESOURCES + f"/database/{connector}/{connector}.yaml") | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |             cls.test_file_path = str( | 
					
						
							|  |  |  |                 Path(PATH_TO_RESOURCES + f"/database/{connector}/test.yaml") | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-06 09:25:10 +02:00
										 |  |  |         @classmethod | 
					
						
							|  |  |  |         def tearDownClass(cls): | 
					
						
							|  |  |  |             workflow = OpenMetadataWorkflowConfig.model_validate( | 
					
						
							| 
									
										
										
										
											2024-09-25 17:37:56 +02:00
										 |  |  |                 load_config_file(Path(cls.config_file_path)) | 
					
						
							| 
									
										
										
										
											2024-09-06 09:25:10 +02:00
										 |  |  |             ) | 
					
						
							|  |  |  |             db_service: DatabaseService = cls.openmetadata.get_by_name( | 
					
						
							|  |  |  |                 DatabaseService, workflow.source.serviceName | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |             if db_service and os.getenv("E2E_CLEAN_DB", "false") == "true": | 
					
						
							|  |  |  |                 cls.openmetadata.delete( | 
					
						
							|  |  |  |                     DatabaseService, db_service.id, hard_delete=True, recursive=True | 
					
						
							|  |  |  |                 ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |         def tearDown(self) -> None: | 
					
						
							|  |  |  |             self.engine.dispose() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         def assert_for_vanilla_ingestion( | 
					
						
							| 
									
										
										
										
											2023-08-30 15:49:42 +02:00
										 |  |  |             self, source_status: Status, sink_status: Status | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |         ) -> None: | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |             self.assertEqual(len(source_status.failures), 0) | 
					
						
							|  |  |  |             self.assertEqual(len(source_status.warnings), 0) | 
					
						
							|  |  |  |             self.assertEqual(len(source_status.filtered), 0) | 
					
						
							|  |  |  |             self.assertGreaterEqual( | 
					
						
							|  |  |  |                 (len(source_status.records) + len(source_status.updated_records)), | 
					
						
							|  |  |  |                 self.expected_tables(), | 
					
						
							| 
									
										
										
										
											2024-01-16 17:53:05 +05:30
										 |  |  |             ) | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |             self.assertEqual(len(sink_status.failures), 0) | 
					
						
							|  |  |  |             self.assertEqual(len(sink_status.warnings), 0) | 
					
						
							|  |  |  |             self.assertGreater( | 
					
						
							|  |  |  |                 (len(sink_status.records) + len(sink_status.updated_records)), | 
					
						
							|  |  |  |                 self.expected_tables(), | 
					
						
							| 
									
										
										
										
											2024-01-16 17:53:05 +05:30
										 |  |  |             ) | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         def assert_for_table_with_profiler( | 
					
						
							| 
									
										
										
										
											2023-08-30 15:49:42 +02:00
										 |  |  |             self, source_status: Status, sink_status: Status | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |         ): | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |             self.assertEqual(len(source_status.failures), 0) | 
					
						
							|  |  |  |             self.assertGreaterEqual( | 
					
						
							|  |  |  |                 (len(source_status.records) + len(source_status.updated_records)), | 
					
						
							|  |  |  |                 self.expected_profiled_tables(), | 
					
						
							| 
									
										
										
										
											2023-04-24 08:00:25 +02:00
										 |  |  |             ) | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |             self.assertEqual(len(sink_status.failures), 0) | 
					
						
							|  |  |  |             self.assertGreaterEqual( | 
					
						
							|  |  |  |                 (len(sink_status.records) + len(sink_status.updated_records)), | 
					
						
							|  |  |  |                 self.expected_profiled_tables(), | 
					
						
							| 
									
										
										
										
											2024-01-16 17:53:05 +05:30
										 |  |  |             ) | 
					
						
							| 
									
										
										
										
											2024-11-13 00:08:55 +05:30
										 |  |  |             # Since we removed view lineage from metadata workflow as part | 
					
						
							|  |  |  |             # of https://github.com/open-metadata/OpenMetadata/pull/18558 | 
					
						
							|  |  |  |             # we need to introduce Lineage E2E base and add view lineage check there. | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-09 14:59:49 +05:30
										 |  |  |         def assert_for_test_lineage(self, source_status: Status, sink_status: Status): | 
					
						
							|  |  |  |             self.assertEqual(len(source_status.failures), 0) | 
					
						
							|  |  |  |             self.assertEqual(len(source_status.warnings), 0) | 
					
						
							|  |  |  |             self.assertEqual(len(sink_status.failures), 0) | 
					
						
							|  |  |  |             self.assertEqual(len(sink_status.warnings), 0) | 
					
						
							| 
									
										
										
										
											2025-03-17 21:00:26 +05:30
										 |  |  |             self.assertGreaterEqual(len(sink_status.records), 0) | 
					
						
							| 
									
										
										
										
											2025-01-09 14:59:49 +05:30
										 |  |  |             lineage_data = self.retrieve_lineage(self.fqn_created_table()) | 
					
						
							|  |  |  |             retrieved_view_column_lineage_count = len( | 
					
						
							|  |  |  |                 lineage_data["downstreamEdges"][0]["lineageDetails"]["columnsLineage"] | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |             self.assertEqual( | 
					
						
							|  |  |  |                 retrieved_view_column_lineage_count, self.view_column_lineage_count() | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             retrieved_lineage_node = lineage_data["nodes"][0]["fullyQualifiedName"] | 
					
						
							|  |  |  |             self.assertEqual(retrieved_lineage_node, self.expected_lineage_node()) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:07:04 +01:00
										 |  |  |         def assert_auto_classification_sample_data( | 
					
						
							|  |  |  |             self, source_status: Status, sink_status: Status | 
					
						
							|  |  |  |         ): | 
					
						
							|  |  |  |             self.assertEqual(len(source_status.failures), 0) | 
					
						
							|  |  |  |             self.assertGreaterEqual( | 
					
						
							|  |  |  |                 (len(source_status.records) + len(source_status.updated_records)), | 
					
						
							|  |  |  |                 self.expected_profiled_tables(), | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |             sample_data = self.retrieve_sample_data(self.fqn_created_table()).sampleData | 
					
						
							| 
									
										
										
										
											2025-01-24 10:44:21 +01:00
										 |  |  |             self.assertEqual(len(sample_data.rows), self.expected_sample_size()) | 
					
						
							| 
									
										
										
										
											2024-11-21 15:07:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-18 11:56:16 +02:00
										 |  |  |         def assert_for_table_with_profiler_time_partition( | 
					
						
							| 
									
										
										
										
											2023-08-30 15:49:42 +02:00
										 |  |  |             self, source_status: Status, sink_status: Status | 
					
						
							| 
									
										
										
										
											2023-04-18 11:56:16 +02:00
										 |  |  |         ): | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |             self.assertEqual(len(source_status.failures), 0) | 
					
						
							|  |  |  |             self.assertEqual(len(sink_status.failures), 0) | 
					
						
							| 
									
										
										
										
											2023-04-18 11:56:16 +02:00
										 |  |  |             profile = self.retrieve_profile(self.fqn_created_table()) | 
					
						
							|  |  |  |             expected_profiler_time_partition_results = ( | 
					
						
							|  |  |  |                 self.get_profiler_time_partition_results() | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |             if expected_profiler_time_partition_results: | 
					
						
							| 
									
										
										
										
											2024-07-04 14:54:41 +02:00
										 |  |  |                 table_profile = profile.profile.model_dump() | 
					
						
							| 
									
										
										
										
											2023-04-18 11:56:16 +02:00
										 |  |  |                 for key in expected_profiler_time_partition_results["table_profile"]: | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |                     self.assertEqual( | 
					
						
							|  |  |  |                         table_profile[key], | 
					
						
							|  |  |  |                         expected_profiler_time_partition_results["table_profile"][key], | 
					
						
							| 
									
										
										
										
											2023-04-18 11:56:16 +02:00
										 |  |  |                     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 for column in profile.columns: | 
					
						
							|  |  |  |                     expected_column_profile = next( | 
					
						
							|  |  |  |                         ( | 
					
						
							| 
									
										
										
										
											2024-06-05 21:18:37 +02:00
										 |  |  |                             profile.get(column.name.root) | 
					
						
							| 
									
										
										
										
											2023-04-18 11:56:16 +02:00
										 |  |  |                             for profile in expected_profiler_time_partition_results[ | 
					
						
							|  |  |  |                                 "column_profile" | 
					
						
							|  |  |  |                             ] | 
					
						
							| 
									
										
										
										
											2024-06-05 21:18:37 +02:00
										 |  |  |                             if profile.get(column.name.root) | 
					
						
							| 
									
										
										
										
											2023-04-18 11:56:16 +02:00
										 |  |  |                         ), | 
					
						
							|  |  |  |                         None, | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |                     if expected_column_profile: | 
					
						
							| 
									
										
										
										
											2024-07-04 14:54:41 +02:00
										 |  |  |                         column_profile = column.profile.model_dump() | 
					
						
							| 
									
										
										
										
											2023-04-18 11:56:16 +02:00
										 |  |  |                         for key in expected_column_profile:  # type: ignore | 
					
						
							| 
									
										
										
										
											2024-03-05 16:00:22 +01:00
										 |  |  |                             if key == "nonParametricSkew": | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |                                 self.assertEqual( | 
					
						
							|  |  |  |                                     column_profile[key].__round__(10), | 
					
						
							|  |  |  |                                     expected_column_profile[key].__round__(10), | 
					
						
							| 
									
										
										
										
											2024-03-05 16:00:22 +01:00
										 |  |  |                                 ) | 
					
						
							|  |  |  |                                 continue | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |                             self.assertEqual( | 
					
						
							|  |  |  |                                 column_profile[key], expected_column_profile[key] | 
					
						
							| 
									
										
										
										
											2023-04-18 11:56:16 +02:00
										 |  |  |                             ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |         def assert_for_delete_table_is_marked_as_deleted( | 
					
						
							| 
									
										
										
										
											2023-08-30 15:49:42 +02:00
										 |  |  |             self, source_status: Status, sink_status: Status | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |         ): | 
					
						
							| 
									
										
										
										
											2023-04-21 08:55:54 +02:00
										 |  |  |             self.assertEqual(self.retrieve_table(self.fqn_deleted_table()), None) | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         def assert_filtered_schemas_includes( | 
					
						
							| 
									
										
										
										
											2023-08-30 15:49:42 +02:00
										 |  |  |             self, source_status: Status, sink_status: Status | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |         ): | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |             self.assertEqual(len(source_status.failures), 0) | 
					
						
							| 
									
										
										
										
											2025-06-28 18:05:58 +05:30
										 |  |  |             self.assertGreaterEqual( | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |                 len(source_status.filtered), self.expected_filtered_schema_includes() | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |             ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         def assert_filtered_schemas_excludes( | 
					
						
							| 
									
										
										
										
											2023-08-30 15:49:42 +02:00
										 |  |  |             self, source_status: Status, sink_status: Status | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |         ): | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |             self.assertEqual(len(source_status.failures), 0) | 
					
						
							| 
									
										
										
										
											2025-06-28 18:05:58 +05:30
										 |  |  |             self.assertGreaterEqual( | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |                 len(source_status.filtered), self.expected_filtered_schema_excludes() | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |             ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         def assert_filtered_tables_includes( | 
					
						
							| 
									
										
										
										
											2023-08-30 15:49:42 +02:00
										 |  |  |             self, source_status: Status, sink_status: Status | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |         ): | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |             self.assertEqual(len(source_status.failures), 0) | 
					
						
							| 
									
										
										
										
											2025-06-28 18:05:58 +05:30
										 |  |  |             self.assertGreaterEqual( | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |                 len(source_status.filtered), self.expected_filtered_table_includes() | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |             ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         def assert_filtered_tables_excludes( | 
					
						
							| 
									
										
										
										
											2023-08-30 15:49:42 +02:00
										 |  |  |             self, source_status: Status, sink_status: Status | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |         ): | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |             self.assertEqual(len(source_status.failures), 0) | 
					
						
							| 
									
										
										
										
											2025-06-28 18:05:58 +05:30
										 |  |  |             self.assertGreaterEqual( | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |                 len(source_status.filtered), self.expected_filtered_table_excludes() | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |             ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-30 15:49:42 +02:00
										 |  |  |         def assert_filtered_mix(self, source_status: Status, sink_status: Status): | 
					
						
							| 
									
										
										
										
											2024-03-08 09:31:06 +01:00
										 |  |  |             self.assertEqual(len(source_status.failures), 0) | 
					
						
							| 
									
										
										
										
											2025-06-28 18:05:58 +05:30
										 |  |  |             self.assertGreaterEqual( | 
					
						
							|  |  |  |                 len(source_status.filtered), self.expected_filtered_mix() | 
					
						
							|  |  |  |             ) | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         @staticmethod | 
					
						
							|  |  |  |         @abstractmethod | 
					
						
							|  |  |  |         def expected_tables() -> int: | 
					
						
							|  |  |  |             raise NotImplementedError() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         @abstractmethod | 
					
						
							| 
									
										
										
										
											2025-01-24 10:44:21 +01:00
										 |  |  |         def expected_sample_size(self) -> int: | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |             raise NotImplementedError() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-27 15:33:03 +01:00
										 |  |  |         @abstractmethod | 
					
						
							|  |  |  |         def view_column_lineage_count(self) -> int: | 
					
						
							|  |  |  |             raise NotImplementedError() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-09 14:59:49 +05:30
										 |  |  |         @abstractmethod | 
					
						
							|  |  |  |         def expected_lineage_node(self) -> str: | 
					
						
							|  |  |  |             raise NotImplementedError() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |         @staticmethod | 
					
						
							|  |  |  |         @abstractmethod | 
					
						
							|  |  |  |         def fqn_created_table() -> str: | 
					
						
							|  |  |  |             raise NotImplementedError() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-21 08:55:54 +02:00
										 |  |  |         @staticmethod | 
					
						
							|  |  |  |         def _fqn_deleted_table() -> Optional[str]: | 
					
						
							|  |  |  |             return None | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-24 08:00:25 +02:00
										 |  |  |         @staticmethod | 
					
						
							|  |  |  |         def _expected_profiled_tables() -> int: | 
					
						
							|  |  |  |             return None | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-21 08:55:54 +02:00
										 |  |  |         def fqn_deleted_table(self) -> str: | 
					
						
							|  |  |  |             if self._fqn_deleted_table() is None: | 
					
						
							|  |  |  |                 return self.fqn_created_table() | 
					
						
							|  |  |  |             return self._fqn_deleted_table()  # type: ignore | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-24 08:00:25 +02:00
										 |  |  |         def expected_profiled_tables(self) -> int: | 
					
						
							|  |  |  |             if self._expected_profiled_tables() is None: | 
					
						
							|  |  |  |                 return self.expected_tables() | 
					
						
							|  |  |  |             return self._expected_profiled_tables() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-10 11:36:20 +02:00
										 |  |  |         @staticmethod | 
					
						
							|  |  |  |         @abstractmethod | 
					
						
							|  |  |  |         def expected_filtered_schema_includes() -> int: | 
					
						
							|  |  |  |             raise NotImplementedError() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         @staticmethod | 
					
						
							|  |  |  |         @abstractmethod | 
					
						
							|  |  |  |         def expected_filtered_schema_excludes() -> int: | 
					
						
							|  |  |  |             raise NotImplementedError() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         @staticmethod | 
					
						
							|  |  |  |         @abstractmethod | 
					
						
							|  |  |  |         def expected_filtered_table_includes() -> int: | 
					
						
							|  |  |  |             raise NotImplementedError() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         @staticmethod | 
					
						
							|  |  |  |         @abstractmethod | 
					
						
							|  |  |  |         def expected_filtered_table_excludes() -> int: | 
					
						
							|  |  |  |             raise NotImplementedError() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         @staticmethod | 
					
						
							|  |  |  |         @abstractmethod | 
					
						
							|  |  |  |         def expected_filtered_mix() -> int: | 
					
						
							|  |  |  |             raise NotImplementedError() |