[postgres] Reuse pool connection based on database in postgres cdc
parent
95af1a5305
commit
a99e3da34b
@ -0,0 +1,129 @@
|
||||
/*
|
||||
* Copyright 2023 Ververica Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
package com.ververica.cdc.connectors.postgres.source;
|
||||
|
||||
import com.ververica.cdc.connectors.postgres.PostgresTestBase;
|
||||
import com.ververica.cdc.connectors.postgres.source.config.PostgresSourceConfigFactory;
|
||||
import com.ververica.cdc.connectors.postgres.testutils.UniqueDatabase;
|
||||
import io.debezium.relational.TableId;
|
||||
import org.junit.Assert;
|
||||
import org.junit.Test;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/** Tests for {@link PostgresDialect}. */
|
||||
public class PostgresDialectTest extends PostgresTestBase {
|
||||
|
||||
private final UniqueDatabase customDatabase =
|
||||
new UniqueDatabase(
|
||||
POSTGRES_CONTAINER,
|
||||
"postgres1",
|
||||
"customer",
|
||||
POSTGRES_CONTAINER.getUsername(),
|
||||
POSTGRES_CONTAINER.getPassword());
|
||||
|
||||
private final UniqueDatabase inventoryDatabase =
|
||||
new UniqueDatabase(
|
||||
POSTGRES_CONTAINER,
|
||||
"postgres2",
|
||||
"inventory",
|
||||
POSTGRES_CONTAINER.getUsername(),
|
||||
POSTGRES_CONTAINER.getPassword());
|
||||
|
||||
@Test
|
||||
public void testDiscoverDataCollectionsInMultiDatabases() {
|
||||
|
||||
// initial two databases in same postgres instance
|
||||
customDatabase.createAndInitialize();
|
||||
inventoryDatabase.createAndInitialize();
|
||||
|
||||
// get table named 'customer.customers' from customDatabase which is actual in
|
||||
// inventoryDatabase
|
||||
PostgresSourceConfigFactory configFactoryOfCustomDatabase =
|
||||
getMockPostgresSourceConfigFactory(
|
||||
customDatabase.getHost(),
|
||||
customDatabase.getDatabasePort(),
|
||||
customDatabase.getUsername(),
|
||||
customDatabase.getPassword(),
|
||||
customDatabase.getDatabaseName(),
|
||||
"customer",
|
||||
"customers");
|
||||
PostgresDialect dialectOfcustomDatabase =
|
||||
new PostgresDialect(configFactoryOfCustomDatabase);
|
||||
List<TableId> tableIdsOfcustomDatabase =
|
||||
dialectOfcustomDatabase.discoverDataCollections(
|
||||
configFactoryOfCustomDatabase.create(0));
|
||||
Assert.assertEquals(tableIdsOfcustomDatabase.get(0).toString(), "customer.customers");
|
||||
|
||||
// get table named 'inventory.products' from customDatabase which is actual in
|
||||
// inventoryDatabase
|
||||
// however, nothing is found
|
||||
PostgresSourceConfigFactory configFactoryOfInventoryDatabase =
|
||||
getMockPostgresSourceConfigFactory(
|
||||
inventoryDatabase.getHost(),
|
||||
inventoryDatabase.getDatabasePort(),
|
||||
inventoryDatabase.getUsername(),
|
||||
inventoryDatabase.getPassword(),
|
||||
inventoryDatabase.getDatabaseName(),
|
||||
"inventory",
|
||||
"products");
|
||||
PostgresDialect dialectOfInventoryDatabase =
|
||||
new PostgresDialect(configFactoryOfInventoryDatabase);
|
||||
List<TableId> tableIdsOfInventoryDatabase =
|
||||
dialectOfInventoryDatabase.discoverDataCollections(
|
||||
configFactoryOfInventoryDatabase.create(0));
|
||||
Assert.assertEquals(tableIdsOfInventoryDatabase.get(0).toString(), "inventory.products");
|
||||
|
||||
// get table named 'customer.customers' from customDatabase which is actual not in
|
||||
// customDatabase
|
||||
// however, something is found
|
||||
PostgresSourceConfigFactory configFactoryOfInventoryDatabase2 =
|
||||
getMockPostgresSourceConfigFactory(
|
||||
inventoryDatabase.getHost(),
|
||||
inventoryDatabase.getDatabasePort(),
|
||||
inventoryDatabase.getUsername(),
|
||||
inventoryDatabase.getPassword(),
|
||||
inventoryDatabase.getDatabaseName(),
|
||||
"customer",
|
||||
"customers");
|
||||
PostgresDialect dialectOfInventoryDatabase2 =
|
||||
new PostgresDialect(configFactoryOfInventoryDatabase2);
|
||||
List<TableId> tableIdsOfInventoryDatabase2 =
|
||||
dialectOfInventoryDatabase2.discoverDataCollections(
|
||||
configFactoryOfInventoryDatabase2.create(0));
|
||||
Assert.assertTrue(tableIdsOfInventoryDatabase2.isEmpty());
|
||||
}
|
||||
|
||||
private static PostgresSourceConfigFactory getMockPostgresSourceConfigFactory(
|
||||
String hostname,
|
||||
int port,
|
||||
String username,
|
||||
String password,
|
||||
String database,
|
||||
String schemaName,
|
||||
String tableName) {
|
||||
PostgresSourceConfigFactory postgresSourceConfigFactory = new PostgresSourceConfigFactory();
|
||||
postgresSourceConfigFactory.hostname(hostname);
|
||||
postgresSourceConfigFactory.port(port);
|
||||
postgresSourceConfigFactory.username(username);
|
||||
postgresSourceConfigFactory.password(password);
|
||||
postgresSourceConfigFactory.database(database);
|
||||
postgresSourceConfigFactory.schemaList(new String[] {schemaName});
|
||||
postgresSourceConfigFactory.tableList(schemaName + "." + tableName);
|
||||
return postgresSourceConfigFactory;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue