1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 package org.apache.shardingsphere.test.it.sql.parser.internal.asserts.statement.rdl.alter.impl;
19
20 import lombok.AccessLevel;
21 import lombok.NoArgsConstructor;
22 import org.apache.shardingsphere.readwritesplitting.distsql.segment.ReadwriteSplittingRuleSegment;
23 import org.apache.shardingsphere.readwritesplitting.distsql.statement.AlterReadwriteSplittingRuleStatement;
24 import org.apache.shardingsphere.test.it.sql.parser.internal.asserts.SQLCaseAssertContext;
25 import org.apache.shardingsphere.test.it.sql.parser.internal.asserts.segment.distsql.rdl.ReadwriteSplittingRuleAssert;
26 import org.apache.shardingsphere.test.it.sql.parser.internal.asserts.statement.ExistingAssert;
27 import org.apache.shardingsphere.test.it.sql.parser.internal.cases.parser.jaxb.segment.impl.distsql.rdl.ExceptedReadwriteSplittingRule;
28 import org.apache.shardingsphere.test.it.sql.parser.internal.cases.parser.jaxb.statement.rdl.rule.readwritesplitting.AlterReadwriteSplittingRuleStatementTestCase;
29
30 import java.util.Collection;
31 import java.util.List;
32
33 import static org.hamcrest.CoreMatchers.is;
34 import static org.junit.jupiter.api.Assertions.assertNotNull;
35 import static org.junit.jupiter.api.Assertions.assertNull;
36 import static org.hamcrest.MatcherAssert.assertThat;
37
38
39
40
41 @NoArgsConstructor(access = AccessLevel.PRIVATE)
42 public final class AlterReadwriteSplittingRuleStatementAssert {
43
44
45
46
47
48
49
50
51 public static void assertIs(final SQLCaseAssertContext assertContext, final AlterReadwriteSplittingRuleStatement actual, final AlterReadwriteSplittingRuleStatementTestCase expected) {
52 if (ExistingAssert.assertIs(assertContext, actual, expected)) {
53 assertReadwriteSplittingRule(assertContext, actual.getRules(), expected.getRules());
54 }
55 }
56
57 private static void assertReadwriteSplittingRule(final SQLCaseAssertContext assertContext, final Collection<ReadwriteSplittingRuleSegment> actual,
58 final List<ExceptedReadwriteSplittingRule> expected) {
59 if (null == expected) {
60 assertNull(actual, assertContext.getText("Actual readwrite-splitting rule should not exist."));
61 } else {
62 assertNotNull(actual, assertContext.getText("Actual readwrite-splitting rule should exist."));
63 assertThat(assertContext.getText(String.format("Actual readwrite-splitting rule size should be %s , but it was %s", expected.size(), actual.size())), actual.size(), is(expected.size()));
64 int count = 0;
65 for (ReadwriteSplittingRuleSegment each : actual) {
66 ReadwriteSplittingRuleAssert.assertIs(assertContext, each, expected.get(count));
67 count++;
68 }
69 }
70 }
71 }