>Java >java지도 시간 >새로운 Java 운동: 테스트 주도 개발 3---사용자 등록 3

새로운 Java 운동: 테스트 주도 개발 3---사용자 등록 3

黄舟
黄舟원래의
2016-12-30 13:15:081205검색

지금까지 우리는 사용자 등록, 즉 데이터베이스에 사용자를 추가하는 실질적인 문제를 다루지 않았습니다. 이제 이 요구 사항을 처리해 보겠습니다.

먼저 데이터베이스 액세스에 사용되는 기술을 결정해야 합니다. 여기에서 Hibernate, JPA 또는 JDBC를 선택할 수 있습니다. 나는 대다수의 애플리케이션이 데이터베이스 액세스 기술로 Hibernate를 사용한다고 생각합니다. 다른 사람들은 JPA를 선택할 수도 있지만 여기서는 JDBC를 선택합니다. 그 이유는 상대적으로 간단합니다. 근본적인 것들이 더 복잡해 보이지만 일단 익히면 내용이 적기 때문에 익히기가 상대적으로 쉽습니다. 이 O-R 매핑 모델은 많은 추상적인 개념과 세부 사항을 추가합니다. 우리는 일반적으로 이러한 아키텍처의 빙산의 일각만을 살펴봅니다. 빙산 아래에 있는 것들을 마스터하려는 경우 JDBC를 직접 마스터하는 것보다 훨씬 더 어렵습니다.

또한 우리의 테스트 중심 개발 아키텍처 덕분에 다른 아키텍처로 변환하려는 경우 테스트 케이스 보장 하에 기존 코드를 안전하게 수정할 수 있습니다.

먼저 DAO 모드를 사용하여 데이터베이스 액세스 인터페이스 클래스인 UserDao를 정의해 보겠습니다. 코드는 다음과 같습니다.

public interface UserDao {  
    public long registerUser(Map<String, Object> userInfo);  
}

일반적으로 우리는 Mysql 데이터베이스를 사용하므로 정의합니다. Dao 클래스 UserMysqlDao의 구현 코드는 다음과 같습니다.

public class UserMysqlDao implements UserDao {  
    @Override  
    public long registerUser(Map<String, Object> userInfo) {  
        // TODO Auto-generated method stub  
        return 0;  
    }

물론 우리는 사용자가 사용된 데이터베이스를 결정한 다음 해당 구현 클래스를 인스턴스화하는 것을 원하지 않습니다. 팩토리 모드를 채택하고 DaoFactory 클래스를 도입해야 합니다. 코드는 다음과 같습니다.

public class DaoFactory {  
    public static UserDao getUserDao() {  
        UserDao dao = null;  
        switch (dbms) {  
        case "mysql":  
            dao = new UserMysqlDao();  
            break;  
        }  
        return dao;  
    }  
      
    public static String getDbms() {  
        return dbms;  
    }  
  
    public static void setDbms(String dbms) {  
        DaoFactory.dbms = dbms;  
    }  
  
    private static String dbms = "mysql";  
}

위 코드에서 볼 수 있듯이 호출자는 구현을 얻기 위해 DaoFactory.getUserDao()만 호출하면 됩니다. 수업.

다음은 데이터베이스 연결 문제입니다. Jboss 등 애플리케이션 서버에서 실행할 때 데이터베이스 연결 풀을 사용하고, 유닛 테스트에서는 DriverManager를 사용하기를 원하므로 DataSource 캡슐화 클래스 JdbcDs를 정의해야 합니다. 위 상황을 처리하세요. 코드는 다음과 같습니다.

public class JdbcDs {	
	public static Connection getConnection() throws SQLException {
		Connection conn = null;
		if (iDebug <= 0) {
			conn = appDs.getConnection();
		} else {
			try {
				Class.forName("com.mysql.jdbc.Driver").newInstance();
			} catch (InstantiationException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} catch (IllegalAccessException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} catch (ClassNotFoundException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
			Properties connectionProps = new Properties();
		    connectionProps.put("user", "root");
		    connectionProps.put("password", "yantao");
		    conn = DriverManager.getConnection(
	                   "jdbc:" + "mysql" + "://" +
	                   "localhost" +
	                   ":" + 3306 + "/XrcjDb",
	                   connectionProps);
		}
		return conn;
	}

	public static int iDebug = 1;
	public final static String APP_DS = "java:jboss/datasources/XcgDS";
	private static DataSource appDs = null; 
	static{
		if (null == appDs) {
			Properties env = new Properties();
			try {
				InitialContext ictx = new InitialContext(env);
				appDs = (DataSource)ictx.lookup(APP_DS);
			} catch (NamingException e1) {
				// TODO Auto-generated catch block
				e1.printStackTrace();
			}
		}
	}
	
}

단위 테스트를 수행할 때 iDebug를 1로 설정하세요. 그렇지 않으면 데이터베이스 연결 풀이 사용됩니다.

모든 준비 작업이 완료되면 정식으로 데이터베이스 기능 개발을 진행할 수 있습니다.

위는 New Java Movement: Test Driven Development 3---사용자 등록 3의 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.