|
16 | 16 |
|
17 | 17 | package com.alibaba.fluss.client.table; |
18 | 18 |
|
19 | | -import com.alibaba.fluss.client.admin.ClientToServerITCaseBase; |
| 19 | +import com.alibaba.fluss.client.Connection; |
| 20 | +import com.alibaba.fluss.client.ConnectionFactory; |
| 21 | +import com.alibaba.fluss.client.admin.Admin; |
20 | 22 | import com.alibaba.fluss.client.scanner.ScanRecord; |
21 | 23 | import com.alibaba.fluss.client.scanner.log.LogScan; |
22 | 24 | import com.alibaba.fluss.client.scanner.log.LogScanner; |
23 | 25 | import com.alibaba.fluss.client.scanner.log.ScanRecords; |
24 | 26 | import com.alibaba.fluss.client.table.writer.AppendWriter; |
25 | 27 | import com.alibaba.fluss.client.table.writer.UpsertWriter; |
| 28 | +import com.alibaba.fluss.config.Configuration; |
26 | 29 | import com.alibaba.fluss.metadata.TablePath; |
27 | 30 | import com.alibaba.fluss.row.InternalRow; |
28 | 31 | import com.alibaba.fluss.row.indexed.IndexedRow; |
| 32 | +import com.alibaba.fluss.server.testutils.FlussClusterExtension; |
29 | 33 |
|
| 34 | +import org.junit.jupiter.api.AfterEach; |
30 | 35 | import org.junit.jupiter.api.BeforeEach; |
31 | 36 | import org.junit.jupiter.api.Test; |
| 37 | +import org.junit.jupiter.api.extension.RegisterExtension; |
32 | 38 |
|
33 | 39 | import java.time.Duration; |
34 | 40 | import java.util.ArrayList; |
35 | 41 | import java.util.List; |
36 | 42 |
|
| 43 | +import static com.alibaba.fluss.client.admin.ClientToServerITCaseBase.initConfig; |
| 44 | +import static com.alibaba.fluss.client.admin.ClientToServerITCaseBase.subscribeFromBeginning; |
37 | 45 | import static com.alibaba.fluss.record.TestData.DATA1_ROW_TYPE; |
38 | 46 | import static com.alibaba.fluss.record.TestData.DATA1_TABLE_INFO; |
39 | 47 | import static com.alibaba.fluss.record.TestData.DATA1_TABLE_INFO_PK; |
|
42 | 50 | import static com.alibaba.fluss.testutils.InternalRowListAssert.assertThatRows; |
43 | 51 |
|
44 | 52 | /** IT case for {@link FlussTable} in the case of one tablet server fails. */ |
45 | | -class FlussFailServerTableITCase extends ClientToServerITCaseBase { |
| 53 | +class FlussFailServerTableITCase { |
| 54 | + |
| 55 | + @RegisterExtension |
| 56 | + public static final FlussClusterExtension FLUSS_CLUSTER_EXTENSION = |
| 57 | + FlussClusterExtension.builder() |
| 58 | + .setNumOfTabletServers(3) |
| 59 | + .setClusterConf(initConfig()) |
| 60 | + .build(); |
46 | 61 |
|
47 | 62 | private static final int SERVER = 0; |
| 63 | + private Connection conn; |
| 64 | + protected Admin admin; |
48 | 65 |
|
49 | 66 | @BeforeEach |
50 | | - void beforeEach() throws Exception { |
| 67 | + void beforeEach() { |
| 68 | + Configuration clientConf = FLUSS_CLUSTER_EXTENSION.getClientConfig(); |
| 69 | + conn = ConnectionFactory.createConnection(clientConf); |
| 70 | + admin = conn.getAdmin(); |
| 71 | + |
51 | 72 | // since we kill and start one tablet server in each test, |
52 | 73 | // we need to wait for metadata to be updated to servers |
53 | 74 | FLUSS_CLUSTER_EXTENSION.waitUtilAllGatewayHasSameMetadata(); |
| 75 | + } |
54 | 76 |
|
55 | | - super.setup(); |
| 77 | + @AfterEach |
| 78 | + protected void teardown() throws Exception { |
| 79 | + if (admin != null) { |
| 80 | + admin.close(); |
| 81 | + admin = null; |
| 82 | + } |
| 83 | + |
| 84 | + if (conn != null) { |
| 85 | + conn.close(); |
| 86 | + conn = null; |
| 87 | + } |
56 | 88 | } |
57 | 89 |
|
58 | 90 | @Test |
|
0 commit comments