@Test public void shouldCreateFilterWithNoDatabaseFilterAndTableBlacklist() { filter = Selectors.tableSelector() .excludeTables("db1\\.A,db1\\.B,db2\\.C") .build(); assertNotAllowed(filter, "db1", "A"); assertNotAllowed(filter, "db1", "B"); assertAllowed(filter, "db1", "D"); assertAllowed(filter, "db1", "E"); assertAllowed(filter, "db1", "F"); assertNotAllowed(filter, "db2", "C"); assertAllowed(filter, "db2", "G"); assertAllowed(filter, "db2", "H"); assertAllowed(filter, "db3", "A"); assertAllowed(filter, "db4", "A"); }
@Test public void shouldCreateFilterWithDatabaseWhitelistAndTableBlacklist() { filter = Selectors.tableSelector() .includeDatabases("db1,db2") .excludeTables("db1\\.A,db1\\.B,db2\\.C") .build(); assertNotAllowed(filter, "db1", "A"); assertNotAllowed(filter, "db1", "B"); assertAllowed(filter, "db1", "D"); assertAllowed(filter, "db1", "E"); assertAllowed(filter, "db1", "F"); assertNotAllowed(filter, "db2", "C"); assertAllowed(filter, "db2", "G"); assertAllowed(filter, "db2", "H"); assertNotAllowed(filter, "db3", "A"); assertNotAllowed(filter, "db4", "A"); }
@Test public void shouldCreateFilterWithDatabaseBlacklistAndTableBlacklist() { filter = Selectors.tableSelector() .excludeDatabases("db3,db4") .excludeTables("db1\\.A,db1\\.B,db2\\.C") .build(); assertNotAllowed(filter, "db1", "A"); assertNotAllowed(filter, "db1", "B"); assertAllowed(filter, "db1", "D"); assertAllowed(filter, "db1", "E"); assertAllowed(filter, "db1", "F"); assertNotAllowed(filter, "db2", "C"); assertAllowed(filter, "db2", "G"); assertAllowed(filter, "db2", "H"); assertNotAllowed(filter, "db3", "A"); assertNotAllowed(filter, "db4", "A"); }
@Test public void shouldCreateFilterWithDatabaseBlacklistAndNoTableFilter() { filter = Selectors.tableSelector() .excludeDatabases("db1,db2") .build(); assertNotAllowed(filter, "db1", "A"); assertNotAllowed(filter, "db2", "A"); assertAllowed(filter, "db3", "A"); assertAllowed(filter, "db4", "A"); }
@Test public void shouldCreateFilterWithDatabaseWhitelistAndNoTableFilter() { filter = Selectors.tableSelector() .includeDatabases("db1,db2") .build(); assertAllowed(filter, "db1", "A"); assertAllowed(filter, "db2", "A"); assertNotAllowed(filter, "db3", "A"); assertNotAllowed(filter, "db4", "A"); }
@Test public void shouldCreateFilterWithSchemaBlacklistAndNoTableFilter() { filter = Selectors.tableSelector() .excludeSchemas("sc1,sc2") .build(); assertNotAllowed(filter, "db1", "sc1", "A"); assertNotAllowed(filter, "db2", "sc2", "A"); assertAllowed(filter, "db1", "sc3", "A"); assertAllowed(filter, "db2", "sc4", "A"); }
@Test public void shouldCreateFilterWithSchemaWhitelistAndNoTableFilter() { filter = Selectors.tableSelector() .includeSchemas("sc1,sc2") .build(); assertAllowed(filter, "db1", "sc1", "A"); assertAllowed(filter, "db2", "sc2", "A"); assertNotAllowed(filter, "db1", "sc3", "A"); assertNotAllowed(filter, "db2", "sc4", "A"); }
@Test public void shouldCreateFilterWithNoDatabaseFilterAndTableWhitelist() { filter = Selectors.tableSelector() .includeTables("db1\\.A,db1\\.B,db2\\.C") .build(); assertAllowed(filter, "db1", "A"); assertAllowed(filter, "db1", "B"); assertNotAllowed(filter, "db1", "D"); assertNotAllowed(filter, "db1", "E"); assertNotAllowed(filter, "db1", "F"); assertAllowed(filter, "db2", "C"); assertNotAllowed(filter, "db2", "G"); assertNotAllowed(filter, "db2", "H"); assertNotAllowed(filter, "db3", "A"); assertNotAllowed(filter, "db4", "A"); }
@Test public void shouldCreateFilterWithAllLists() { filter = Selectors.tableSelector() .includeDatabases("connector_test") .excludeDatabases("") .includeTables("") .excludeTables("") .build(); assertAllowed(filter, "connector_test", "A"); assertAllowed(filter, "connector_test", "B"); assertNotAllowed(filter, "other_test", "A"); assertNotAllowed(filter, "other_test", "B"); }
@Test public void shouldCreateFilterWithDatabaseWhitelistAndTableWhitelist() { filter = Selectors.tableSelector() .includeDatabases("db1,db2") .includeTables("db1\\.A,db1\\.B,db2\\.C") .build(); assertAllowed(filter, "db1", "A"); assertAllowed(filter, "db1", "B"); assertNotAllowed(filter, "db1", "D"); assertNotAllowed(filter, "db1", "E"); assertNotAllowed(filter, "db1", "F"); assertAllowed(filter, "db2", "C"); assertNotAllowed(filter, "db2", "G"); assertNotAllowed(filter, "db2", "H"); assertNotAllowed(filter, "db3", "A"); assertNotAllowed(filter, "db4", "A"); }
@Test public void shouldCreateFilterWithDatabaseBlacklistAndTableWhitelist() { filter = Selectors.tableSelector() .excludeDatabases("db3,db4") .includeTables("db1\\.A,db1\\.B,db2\\.C") .build(); assertAllowed(filter, "db1", "A"); assertAllowed(filter, "db1", "B"); assertNotAllowed(filter, "db1", "D"); assertNotAllowed(filter, "db1", "E"); assertNotAllowed(filter, "db1", "F"); assertAllowed(filter, "db2", "C"); assertNotAllowed(filter, "db2", "G"); assertNotAllowed(filter, "db2", "H"); assertNotAllowed(filter, "db3", "A"); assertNotAllowed(filter, "db4", "A"); }
@Test public void shouldCreateFilterWithSchemaWhitelistAndTableWhitelist() { filter = Selectors.tableSelector() .includeSchemas("sc1,sc2") .includeTables("db\\.sc1\\.A,db\\.sc2\\.B") .build(); assertAllowed(filter, "db", "sc1", "A"); assertNotAllowed(filter, "db", "sc1", "B"); assertAllowed(filter, "db", "sc2", "B"); assertNotAllowed(filter, "db", "sc2", "A"); assertNotAllowed(filter, "db", "sc1", "C"); assertNotAllowed(filter, "db2", "sc2", "D"); assertNotAllowed(filter, "db", "sc3", "A"); assertNotAllowed(filter, "db2", "sc4", "B"); }