| 
									
										
										
										
											2022-07-07 08:28:34 -07:00
										 |  |  | import subprocess | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-01 12:15:05 -07:00
										 |  |  | import pytest | 
					
						
							| 
									
										
										
										
											2021-07-29 20:04:40 -07:00
										 |  |  | from freezegun import freeze_time | 
					
						
							| 
									
										
										
										
											2021-02-11 12:53:44 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-14 23:01:51 +05:30
										 |  |  | from datahub.ingestion.source.sql.mysql import MySQLSource | 
					
						
							|  |  |  | from tests.test_helpers import mce_helpers, test_connection_helpers | 
					
						
							| 
									
										
										
										
											2021-12-16 23:07:38 -05:00
										 |  |  | from tests.test_helpers.click_helpers import run_datahub_cmd | 
					
						
							| 
									
										
										
										
											2021-04-13 17:30:24 -07:00
										 |  |  | from tests.test_helpers.docker_helpers import wait_for_port | 
					
						
							| 
									
										
										
										
											2021-02-09 01:02:05 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-29 20:04:40 -07:00
										 |  |  | FROZEN_TIME = "2020-04-14 07:00:00" | 
					
						
							| 
									
										
										
										
											2022-07-07 08:28:34 -07:00
										 |  |  | MYSQL_PORT = 3306 | 
					
						
							| 
									
										
										
										
											2021-02-11 12:24:20 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-29 20:04:40 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-07 08:28:34 -07:00
										 |  |  | @pytest.fixture(scope="module") | 
					
						
							|  |  |  | def test_resources_dir(pytestconfig): | 
					
						
							|  |  |  |     return pytestconfig.rootpath / "tests/integration/mysql" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def is_mysql_up(container_name: str, port: int) -> bool: | 
					
						
							|  |  |  |     """A cheap way to figure out if mysql is responsive on a container""" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cmd = f"docker logs {container_name} 2>&1 | grep '/usr/sbin/mysqld: ready for connections.' | grep {port}" | 
					
						
							|  |  |  |     ret = subprocess.run( | 
					
						
							|  |  |  |         cmd, | 
					
						
							|  |  |  |         shell=True, | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     return ret.returncode == 0 | 
					
						
							| 
									
										
										
										
											2021-02-09 01:02:05 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-07 08:28:34 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | @pytest.fixture(scope="module") | 
					
						
							|  |  |  | def mysql_runner(docker_compose_runner, pytestconfig, test_resources_dir): | 
					
						
							| 
									
										
										
										
											2021-04-13 17:30:24 -07:00
										 |  |  |     with docker_compose_runner( | 
					
						
							|  |  |  |         test_resources_dir / "docker-compose.yml", "mysql" | 
					
						
							|  |  |  |     ) as docker_services: | 
					
						
							| 
									
										
										
										
											2022-07-07 08:28:34 -07:00
										 |  |  |         wait_for_port( | 
					
						
							|  |  |  |             docker_services, | 
					
						
							|  |  |  |             "testmysql", | 
					
						
							|  |  |  |             MYSQL_PORT, | 
					
						
							|  |  |  |             timeout=120, | 
					
						
							|  |  |  |             checker=lambda: is_mysql_up("testmysql", MYSQL_PORT), | 
					
						
							| 
									
										
										
										
											2021-12-16 23:07:38 -05:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2022-07-07 08:28:34 -07:00
										 |  |  |         yield docker_services | 
					
						
							| 
									
										
										
										
											2022-03-09 12:29:58 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-07 19:05:50 -04:00
										 |  |  | @pytest.mark.parametrize( | 
					
						
							|  |  |  |     "config_file,golden_file", | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         ("mysql_to_file_with_db.yml", "mysql_mces_with_db_golden.json"), | 
					
						
							|  |  |  |         ("mysql_to_file_no_db.yml", "mysql_mces_no_db_golden.json"), | 
					
						
							|  |  |  |         ("mysql_profile_table_level_only.yml", "mysql_table_level_only.json"), | 
					
						
							| 
									
										
										
										
											2023-07-19 22:36:26 -04:00
										 |  |  |         ( | 
					
						
							|  |  |  |             "mysql_profile_table_row_count_estimate_only.yml", | 
					
						
							|  |  |  |             "mysql_table_row_count_estimate_only.json", | 
					
						
							|  |  |  |         ), | 
					
						
							| 
									
										
										
										
											2023-07-07 19:05:50 -04:00
										 |  |  |     ], | 
					
						
							|  |  |  | ) | 
					
						
							| 
									
										
										
										
											2022-03-09 12:29:58 -05:00
										 |  |  | @freeze_time(FROZEN_TIME) | 
					
						
							|  |  |  | @pytest.mark.integration | 
					
						
							| 
									
										
										
										
											2022-08-26 23:17:49 +05:30
										 |  |  | def test_mysql_ingest_no_db( | 
					
						
							| 
									
										
										
										
											2023-07-07 19:05:50 -04:00
										 |  |  |     mysql_runner, | 
					
						
							|  |  |  |     pytestconfig, | 
					
						
							|  |  |  |     test_resources_dir, | 
					
						
							|  |  |  |     tmp_path, | 
					
						
							|  |  |  |     mock_time, | 
					
						
							|  |  |  |     config_file, | 
					
						
							|  |  |  |     golden_file, | 
					
						
							| 
									
										
										
										
											2022-08-26 23:17:49 +05:30
										 |  |  | ): | 
					
						
							|  |  |  |     # Run the metadata ingestion pipeline. | 
					
						
							| 
									
										
										
										
											2023-07-07 19:05:50 -04:00
										 |  |  |     config_file = (test_resources_dir / config_file).resolve() | 
					
						
							| 
									
										
										
										
											2023-03-13 13:32:40 -07:00
										 |  |  |     run_datahub_cmd(["ingest", "-c", f"{config_file}"], tmp_path=tmp_path) | 
					
						
							| 
									
										
										
										
											2022-08-26 23:17:49 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  |     # Verify the output. | 
					
						
							|  |  |  |     mce_helpers.check_golden_file( | 
					
						
							|  |  |  |         pytestconfig, | 
					
						
							|  |  |  |         output_path=tmp_path / "mysql_mces.json", | 
					
						
							| 
									
										
										
										
											2023-07-07 19:05:50 -04:00
										 |  |  |         golden_path=test_resources_dir / golden_file, | 
					
						
							| 
									
										
										
										
											2022-07-07 08:28:34 -07:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2023-12-14 23:01:51 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @pytest.mark.parametrize( | 
					
						
							|  |  |  |     "config_dict, is_success", | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         ( | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 "host_port": "localhost:53307", | 
					
						
							|  |  |  |                 "database": "northwind", | 
					
						
							|  |  |  |                 "username": "root", | 
					
						
							|  |  |  |                 "password": "example", | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             True, | 
					
						
							|  |  |  |         ), | 
					
						
							|  |  |  |         ( | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 "host_port": "localhost:5330", | 
					
						
							|  |  |  |                 "database": "wrong_db", | 
					
						
							|  |  |  |                 "username": "wrong_user", | 
					
						
							|  |  |  |                 "password": "wrong_pass", | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             False, | 
					
						
							|  |  |  |         ), | 
					
						
							|  |  |  |     ], | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | @freeze_time(FROZEN_TIME) | 
					
						
							|  |  |  | @pytest.mark.integration | 
					
						
							|  |  |  | def test_mysql_test_connection(mysql_runner, config_dict, is_success): | 
					
						
							|  |  |  |     report = test_connection_helpers.run_test_connection(MySQLSource, config_dict) | 
					
						
							|  |  |  |     if is_success: | 
					
						
							|  |  |  |         test_connection_helpers.assert_basic_connectivity_success(report) | 
					
						
							|  |  |  |     else: | 
					
						
							|  |  |  |         test_connection_helpers.assert_basic_connectivity_failure( | 
					
						
							|  |  |  |             report, "Connection refused" | 
					
						
							|  |  |  |         ) |