您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Springboot Cucumber測試配置的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
目前Spring-boot成為了java開發的主流框架,Cucumber作為一款支持dsl的自動化測試工具,很適合用戶編寫DSL優化過的單元測試等測試用例。
目錄結構如下:
gradle相關配置如下所示:
testCompile('org.springframework.boot:spring-boot-starter-test', "info.cukes:cucumber-jvm:1.1.8", "info.cukes:cucumber-core:1.1.8", "info.cukes:cucumber-java:1.1.8", "info.cukes:cucumber-junit:1.1.8", "info.cukes:cucumber-spring:1.1.8", 'commons-io:commons-io:2.4')
src中為常見的spring代碼結構,我們不再具體講解。test文件夾中上邊為自帶的SpringBootTest測試框架,而demo中的內容是Cucumber框架的具體配置。
1.首先我們需要配置基本的Cucumber框架CucumberTest.java:
@RunWith(Cucumber.class) @CucumberOptions(features = "src/test/resources") public class CucumberTest { }
2.接下來,我們要配置有關Spring-boot的配置,因為我們的測試框架也需要在springboot的運行下完成AbstractDefs.java:
@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(classes = TestSpringMongoApplication.class) @WebAppConfiguration @SpringBootTest public class AbstractDefs { }
3.然后,我們便開始寫屬于我們的DSL解析語法,可具體的測試流程TestSteps.java:
import com.tiandi.service.FaultInjectionInfoService; import cucumber.api.java.en.And; import cucumber.api.java.en.Given; import cucumber.api.java.en.Then; import cucumber.api.java.en.When; import org.springframework.beans.factory.annotation.Autowired; public class TestSteps extends AbstractDefs { @Autowired private FaultInjectionInfoService faultInjectionInfoService; private String faultNodeId; @Given("^Generate testCase for \"([^\"]*)\"$") public void generateTestCase(String id) { faultNodeId = id; } @Then("^finish$") public void finish() { faultInjectionInfoService.generateTestCase(faultNodeId); } } //在這里,我們通過Autowired注入了spring中的service,并編寫用戶自定義的DSL來調用service中的方法執行,獲得測試結果。
4.最后,我們在resources中填寫具體的黃瓜測試用例,并執行。
Feature: test cucumber Scenario: system out print something Given Generate testCase for "COM-COM-F" Then finish
5.測試結果如圖所示
綠色代表測試通過
關于“Springboot Cucumber測試配置的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。