1 package org.apache.commons.jcs.auxiliary.disk.jdbc;
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 import java.sql.Connection;
23 import java.sql.DriverManager;
24 import java.sql.SQLException;
25 import java.util.Properties;
26
27 import org.apache.commons.jcs.JCS;
28 import org.apache.commons.jcs.access.CacheAccess;
29
30 import junit.framework.TestCase;
31
32
33 public class JDBCDiskCacheRemovalUnitTest
34 extends TestCase
35 {
36
37 private final String databaseName = "JCS_STORE_REMOVAL";
38
39
40
41
42 @Override
43 public void setUp()
44 {
45 System.setProperty( "DATABASE_NAME", databaseName );
46 JCS.setConfigFilename( "/TestJDBCDiskCacheRemoval.ccf" );
47 }
48
49
50
51
52
53
54
55 public void testPartialKeyRemoval_Good()
56 throws Exception
57 {
58
59 setupDatabase();
60
61 String keyPart1 = "part1";
62 String keyPart2 = "part2";
63 String region = "testCache1";
64 String data = "adfadsfasfddsafasasd";
65
66 CacheAccess<String, String> jcs = JCS.getInstance( region );
67
68
69 jcs.put( keyPart1 + ":" + keyPart2, data );
70 Thread.sleep( 1000 );
71
72
73 String resultBeforeRemove = jcs.get( keyPart1 + ":" + keyPart2 );
74 assertEquals( "Wrong result", data, resultBeforeRemove );
75
76 jcs.remove( keyPart1 + ":" );
77 String resultAfterRemove = jcs.get( keyPart1 + ":" + keyPart2 );
78 assertNull( "Should not have a result after removal.", resultAfterRemove );
79
80
81 }
82
83
84
85
86
87
88
89
90 private void setupDatabase()
91 throws InstantiationException, IllegalAccessException, ClassNotFoundException, SQLException
92 {
93 System.setProperty( "hsqldb.cache_scale", "8" );
94
95 String rafroot = "target";
96 Properties p = new Properties();
97 String driver = p.getProperty( "driver", "org.hsqldb.jdbcDriver" );
98 String url = p.getProperty( "url", "jdbc:hsqldb:" );
99 String database = p.getProperty( "database", rafroot + "/JDBCDiskCacheRemovalUnitTest" );
100 String user = p.getProperty( "user", "sa" );
101 String password = p.getProperty( "password", "" );
102
103 new org.hsqldb.jdbcDriver();
104 Class.forName( driver ).newInstance();
105 Connection cConn = DriverManager.getConnection( url + database, user, password );
106
107 HsqlSetupTableUtil.setupTABLE( cConn, databaseName );
108 }
109 }