Search in sources :

Example 11 with TableRule

use of io.shardingjdbc.core.rule.TableRule in project sharding-jdbc by shardingjdbc.

the class ShardingNamespaceTest method assertMultiTableRulesDataSource.

@Test
public void assertMultiTableRulesDataSource() {
    ShardingRule shardingRule = getShardingRule("multiTableRulesDataSource");
    assertThat(shardingRule.getTableRules().size(), is(2));
    Iterator<TableRule> tableRules = shardingRule.getTableRules().iterator();
    assertThat(tableRules.next().getLogicTable(), is("t_order"));
    assertThat(tableRules.next().getLogicTable(), is("t_order_item"));
}
Also used : BindingTableRule(io.shardingjdbc.core.rule.BindingTableRule) TableRule(io.shardingjdbc.core.rule.TableRule) ShardingRule(io.shardingjdbc.core.rule.ShardingRule) Test(org.junit.Test)

Example 12 with TableRule

use of io.shardingjdbc.core.rule.TableRule in project sharding-jdbc by shardingjdbc.

the class ShardingNamespaceTest method assertDefaultActualDataNodes.

@Test
public void assertDefaultActualDataNodes() {
    ShardingDataSource multiTableRulesDataSource = this.applicationContext.getBean("multiTableRulesDataSource", ShardingDataSource.class);
    Object shardingContext = FieldValueUtil.getFieldValue(multiTableRulesDataSource, "shardingContext", true);
    ShardingRule shardingRule = (ShardingRule) FieldValueUtil.getFieldValue(shardingContext, "shardingRule");
    assertThat(shardingRule.getTableRules().size(), is(2));
    Iterator<TableRule> tableRules = shardingRule.getTableRules().iterator();
    TableRule orderRule = tableRules.next();
    assertThat(orderRule.getActualDataNodes().size(), is(2));
    assertTrue(orderRule.getActualDataNodes().contains(new DataNode("dbtbl_0", "t_order")));
    assertTrue(orderRule.getActualDataNodes().contains(new DataNode("dbtbl_1", "t_order")));
    TableRule orderItemRule = tableRules.next();
    assertThat(orderItemRule.getActualDataNodes().size(), is(2));
    assertTrue(orderItemRule.getActualDataNodes().contains(new DataNode("dbtbl_0", "t_order_item")));
    assertTrue(orderItemRule.getActualDataNodes().contains(new DataNode("dbtbl_1", "t_order_item")));
}
Also used : BindingTableRule(io.shardingjdbc.core.rule.BindingTableRule) TableRule(io.shardingjdbc.core.rule.TableRule) ShardingDataSource(io.shardingjdbc.core.jdbc.core.datasource.ShardingDataSource) SpringShardingDataSource(io.shardingjdbc.spring.datasource.SpringShardingDataSource) DataNode(io.shardingjdbc.core.rule.DataNode) ShardingRule(io.shardingjdbc.core.rule.ShardingRule) Test(org.junit.Test)

Aggregations

TableRule (io.shardingjdbc.core.rule.TableRule)12 Test (org.junit.Test)7 BindingTableRule (io.shardingjdbc.core.rule.BindingTableRule)6 DataNode (io.shardingjdbc.core.rule.DataNode)6 ShardingRule (io.shardingjdbc.core.rule.ShardingRule)6 LinkedList (java.util.LinkedList)4 InlineShardingStrategyConfiguration (io.shardingjdbc.core.api.config.strategy.InlineShardingStrategyConfiguration)2 StandardShardingStrategyConfiguration (io.shardingjdbc.core.api.config.strategy.StandardShardingStrategyConfiguration)2 ShardingDataSource (io.shardingjdbc.core.jdbc.core.datasource.ShardingDataSource)2 QueryResult (io.shardingjdbc.core.merger.QueryResult)2 MemoryQueryResultRow (io.shardingjdbc.core.merger.dql.common.MemoryQueryResultRow)2 ShardingValue (io.shardingjdbc.core.api.algorithm.sharding.ShardingValue)1 SQLParsingEngine (io.shardingjdbc.core.parsing.SQLParsingEngine)1 GeneratedKeyToken (io.shardingjdbc.core.parsing.parser.token.GeneratedKeyToken)1 ItemsToken (io.shardingjdbc.core.parsing.parser.token.ItemsToken)1 TableUnit (io.shardingjdbc.core.routing.type.TableUnit)1 SpringShardingDataSource (io.shardingjdbc.spring.datasource.SpringShardingDataSource)1 DecrementKeyGenerator (io.shardingjdbc.spring.fixture.DecrementKeyGenerator)1 IncrementKeyGenerator (io.shardingjdbc.spring.fixture.IncrementKeyGenerator)1 Collection (java.util.Collection)1