Blame view

src/test/java/fr/plil/sio/persistence/jdbc/AbstractServiceSupport.java 2.37 KB
292aec6f   jcartign   First version bef...
1
2
3
4
5
6
7
8
9
10
  package fr.plil.sio.persistence.jdbc;
  
  import org.junit.After;
  import org.junit.Before;
  import org.springframework.beans.factory.annotation.Autowired;
  
  import javax.sql.DataSource;
  import java.sql.Connection;
  import java.sql.SQLException;
  import java.sql.Statement;
7a831760   msahmane   Version où les te...
11
12
  import org.slf4j.Logger;
  import org.slf4j.LoggerFactory;
292aec6f   jcartign   First version bef...
13
14
15
  
  public abstract class AbstractServiceSupport {
  
7a831760   msahmane   Version où les te...
16
17
      private static final Logger logger = LoggerFactory.getLogger(AbstractServiceSupport.class);
      
292aec6f   jcartign   First version bef...
18
19
20
      private static final String create_table_group = "CREATE TABLE GROUP_T (GROUP_ID INT NOT NULL AUTO_INCREMENT, " +
              "NAME_C VARCHAR(50) UNIQUE NOT NULL, PRIMARY KEY(GROUP_ID))";
  
7a831760   msahmane   Version où les te...
21
22
23
24
25
26
      private static final String create_table_right = "CREATE TABLE RIGHT_T (RIGHT_ID INT NOT NULL AUTO_INCREMENT, "+ 
              "NAME_R VARCHAR(50) UNIQUE NOT NULL, PRIMARY KEY(RIGHT_ID), PARENT INT, FOREIGN KEY(PARENT) REFERENCES RIGHT_T(RIGHT_ID))";
      
      private static final String create_table_user = "CREATE TABLE USER_T (USER_ID INT NOT NULL AUTO_INCREMENT, "+
              "NAME_U VARCHAR(50) UNIQUE NOT NULL, PRIMARY KEY(USER_ID), GROUP_U INT, FOREIGN KEY(GROUP_U) REFERENCES GROUP_T(GROUP_ID)) ";        
      
292aec6f   jcartign   First version bef...
27
      private static final String drop_table_group = "DROP TABLE GROUP_T";
7a831760   msahmane   Version où les te...
28
29
30
31
      
      private static final String drop_table_right = "DROP TABLE RIGHT_T";
      
      private static final String drop_table_user = "DROP TABLE USER_T";
292aec6f   jcartign   First version bef...
32
33
34
35
36
37
38
39
40
41
  
      @Autowired
      private DataSource dataSource;
  
      private Connection connection;
  
      private Statement stmt;
  
      @Before
      public void createTables() throws SQLException {
7a831760   msahmane   Version où les te...
42
          logger.debug("createTables");
292aec6f   jcartign   First version bef...
43
44
          openConnection();
          stmt.executeUpdate(create_table_group);
7a831760   msahmane   Version où les te...
45
46
          stmt.executeUpdate(create_table_right);
          stmt.executeUpdate(create_table_user);
292aec6f   jcartign   First version bef...
47
48
49
50
51
          closeConnection();
      }
  
      @After
      public void cleanupDatabase() throws SQLException {
7a831760   msahmane   Version où les te...
52
          logger.debug("cleanupDatabase");        
292aec6f   jcartign   First version bef...
53
54
          openConnection();
          stmt.executeUpdate(drop_table_group);
7a831760   msahmane   Version où les te...
55
56
          stmt.executeUpdate(drop_table_right);
          stmt.executeUpdate(drop_table_user);
292aec6f   jcartign   First version bef...
57
58
59
60
61
62
63
64
65
66
67
68
69
          closeConnection();
      }
  
      private void closeConnection() throws SQLException {
          stmt.close();
          connection.close();
      }
  
      private void openConnection() throws SQLException {
          connection = dataSource.getConnection();
          stmt = connection.createStatement();
      }
  }