-
Notifications
You must be signed in to change notification settings - Fork 21
Expand file tree
/
Copy pathMigrationEngineItemsTest.java
More file actions
91 lines (70 loc) · 3.17 KB
/
MigrationEngineItemsTest.java
File metadata and controls
91 lines (70 loc) · 3.17 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
package io.smartcat.migration;
import static junit.framework.Assert.assertEquals;
import com.datastax.driver.core.*;
import com.datastax.driver.core.querybuilder.QueryBuilder;
import io.smartcat.migration.migrations.data.InsertInitialItemsMigration;
import io.smartcat.migration.migrations.data.PopulateItemByNumberAndExternalIdMigration;
import io.smartcat.migration.migrations.schema.CreateItemByNumberAndExternalIdMigration;
import org.cassandraunit.CQLDataLoader;
import org.cassandraunit.dataset.cql.ClassPathCQLDataSet;
import org.cassandraunit.utils.EmbeddedCassandraServerHelper;
import org.junit.After;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.List;
public class MigrationEngineItemsTest extends BaseTest {
private static final Logger LOGGER = LoggerFactory.getLogger(MigrationEngineItemsTest.class);
private static final String CONTACT_POINT = "localhost";
private static final int PORT = 9142;
private static final String KEYSPACE = "migration_test_items";
private static final String CQL = "items.cql";
private static Session session;
private static Cluster cluster;
@BeforeClass
public static void init() throws Exception {
LOGGER.info("Starting embedded cassandra server");
EmbeddedCassandraServerHelper.startEmbeddedCassandra("another-cassandra.yaml");
LOGGER.info("Connect to embedded db");
cluster = Cluster.builder().addContactPoints(CONTACT_POINT).withPort(PORT).build();
session = cluster.connect();
LOGGER.info("Initialize keyspace");
final CQLDataLoader cqlDataLoader = new CQLDataLoader(session);
cqlDataLoader.load(new ClassPathCQLDataSet(CQL, false, true, KEYSPACE));
}
@After
public void cleanUp() {
truncateTables(KEYSPACE, session);
}
@AfterClass
public static void tearDown() {
if (cluster != null) {
cluster.close();
cluster = null;
}
}
@Test
public void initial_insert_test() {
final int count = 100;
final MigrationResources resources = new MigrationResources();
resources.addMigration(new InsertInitialItemsMigration(count, 1));
final boolean result = MigrationEngine.withSession(session).migrate(resources);
assertEquals(true, result);
final List<Row> rows = session.execute(QueryBuilder.select().from("items_by_id")).all();
assertEquals(count, rows.size());
}
@Test
public void test_migrations() {
final int count = 100;
final MigrationResources resources = new MigrationResources();
resources.addMigration(new InsertInitialItemsMigration(count, 1));
resources.addMigration(new CreateItemByNumberAndExternalIdMigration(1));
resources.addMigration(new PopulateItemByNumberAndExternalIdMigration(2));
final boolean result = MigrationEngine.withSession(session).migrate(resources);
assertEquals(true, result);
final List<Row> rows = session.execute(QueryBuilder.select().from("items_by_number_external_id")).all();
assertEquals(count, rows.size());
}
}