第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Spring 測試 @SqlGroup 和 @PostConstruct on bean

Spring 測試 @SqlGroup 和 @PostConstruct on bean

MMTTMM 2021-08-25 10:09:04
在使用Spring 5、Junit4.11 和 JDK8運行一些集成測試之前,我試圖用 @SqlGroup 執(zhí)行一些 SQL 語句。直到今天,當我在“ConfigurationComponent”bean 上添加了一些初始配置時,一切都完美無缺,并帶有 @PostConstruct 注釋。當@PostConstruct 方法調(diào)用依賴于數(shù)據(jù)庫的 bean 時,測試失敗,因為 hiberante(因此數(shù)據(jù)庫)找不到預加載的模式。經(jīng)過調(diào)查,發(fā)現(xiàn)@SqlGroup 中的語句會在ApplicationContext 初始化之后執(zhí)行,所以@PostConstruct 在schema 加載之前執(zhí)行。這是我的集成測試抽象類。@RunWith(SpringJUnit4ClassRunner.class)@ContextConfiguration(locations = { "classpath:application-context-test.xml" })@Transactional@Rollback(true)@SqlGroup({        @Sql(executionPhase = ExecutionPhase.BEFORE_TEST_METHOD, scripts = {                "classpath:db_config.sql",                "classpath:consultas/setup_esquema_0.1.sql",                "classpath:db_datos_iniciales.sql"}),        @Sql(executionPhase = ExecutionPhase.AFTER_TEST_METHOD, scripts = "classpath:db_teardown.sql") })public abstract class AbstractServiceTest {    @BeforeClass    public static void setUpBeforeClass() throws Exception {    }    @AfterClass    public static void tearDownAfterClass() throws Exception {    }    @Before    public abstract void setUp() throws Exception;    @After    public abstract void tearDown() throws Exception;    public static Long randomId() {        return new Long(Math.round(Math.random() * 1000));    }}我找不到使用@SqlGroup 解決此問題的方法。有沒有解決方案,一種改變生命周期并首先執(zhí)行sql語句的方法?如您所見,我正在使用ExecutionPhase.BEFORE_TEST_METHOD,這種情況沒有明確的配置,例如“ExecutionPhase.BEFORE_SETUP”。2018 年 9 月 7 日更新 - 使用 @Sql 似乎無法實現(xiàn)此目的:@Sql 和 @PostConstruct 的調(diào)用都由 Spring Framework 處理,而不是 Spring Boot。另外,我相信這是按設計工作的。@Sql 的默認執(zhí)行階段是 BEFORE_TEST_METHOD(另一個選項是 AFTER_TEST_METHOD)。應用程序上下文被刷新,因此 @PostConstruct 被調(diào)用一次,整個測試類(實際上,如果多個測試類共享相同的配置,它可能是一次),這發(fā)生在調(diào)用單個測試方法之前。換句話說,您不能使用@Sql 作為為@PostConstruct 中進行的調(diào)用準備數(shù)據(jù)庫的方法。
查看完整描述

2 回答

?
largeQ

TA貢獻2039條經(jīng)驗 獲得超8個贊

另一種解決方法是實施 CommandLineRunner。


@Component

public class ConfigurationInitRunner implements CommandLineRunner {


    @Autowired

    Resources resources; // resources are retrieved from database.


    @Override

    public void run(String... strings) throws Exception {

        Config.environment = resources.getWsaaEnv();

        Config.validation = resources.getWsaaEnvValidation();

    }

}


查看完整回答
反對 回復 2021-08-25
?
九州編程

TA貢獻1785條經(jīng)驗 獲得超4個贊

我設法找到了解決方法。正如最新更新所述,使用@SqlGroup 無法實現(xiàn)所需的行為。我不得不使用以下方法,使用@BeforeClass 和@AfterClass:


@BeforeClass

public static void setUpBeforeClass() throws Exception {


    DriverManagerDataSource dataSource = getDataSource();

    Connection conn = dataSource.getConnection();

    ScriptUtils.executeSqlScript(conn, new ClassPathResource("db_config.sql"));

    ScriptUtils.executeSqlScript(conn, new ClassPathResource("consultas/setup_schema"));

    ScriptUtils.executeSqlScript(conn, new ClassPathResource("db_init.sql"));

    JdbcUtils.closeConnection(conn);


}


@AfterClass

public static void tearDownAfterClass() throws Exception {

    Connection conn = getDataSource().getConnection();

    ScriptUtils.executeSqlScript(conn, new ClassPathResource(

            "db_teardown.sql"));

    JdbcUtils.closeConnection(conn);

}


private static DriverManagerDataSource getDataSource() {

    DriverManagerDataSource dataSource = new DriverManagerDataSource();

    dataSource.setUrl(url);

    dataSource.setUsername(username);

    dataSource.setPassword(password);

    dataSource.setDriverClassName(driver);

    return dataSource;

}

刪除了所有@SqlGroup 注釋。這種方法非常干凈,因為 ScriptUtils 不需要太多的依賴來運行。


查看完整回答
反對 回復 2021-08-25
  • 2 回答
  • 0 關注
  • 234 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號