亚洲AVI,黑人巨茎大战欧美白妇,初高中生洗澡自慰高清网站,欧美日韩无砖专区一中文字

重慶分公司,新征程啟航

為企業(yè)提供網(wǎng)站建設(shè)、域名注冊、服務(wù)器等服務(wù)

SpringSecurity測試實戰(zhàn)

引言

創(chuàng)新互聯(lián)建站服務(wù)項目包括延川網(wǎng)站建設(shè)、延川網(wǎng)站制作、延川網(wǎng)頁制作以及延川網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,延川網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到延川省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

試題管理系統(tǒng)的安全模塊使用Spring Security,代碼從原華軟倉庫移植,在移植的過程中,發(fā)現(xiàn)原測試編寫的不好,遂在新系統(tǒng)中對安全模塊測試進(jìn)行了重構(gòu)。

Spring 測試

添加@SpringBootTest注解,意為這是一個基于SpringBoot的單元測試。

SpringBoot在官方的Guide中提供了多種測試方式。

@SpringBootTest注解中的webEnvironment屬性可以配置測試環(huán)境,默認(rèn)為MOCK環(huán)境。

/**
 * The type of web environment to create when applicable. Defaults to
 * {@link WebEnvironment#MOCK}.
 * @return the type of web environment
 */
WebEnvironment webEnvironment() default WebEnvironment.MOCK;

模擬環(huán)境測試

啟用Spring Security后,單元測試中對api的測試會被Spring Security的Filter進(jìn)行攔截,所以測試之前需要進(jìn)行用戶登錄操作。

之前都是使用比較笨重的方法,寫一個@Before,@Before里進(jìn)行登錄,之后再執(zhí)行測試方法。

最近在閱讀Spring Security Test文檔之后,終于找到一種模擬登錄十分簡便的方法,@WithMockUser。

test method with mock user - spring security test

引入Spring Security Test依賴:



  org.springframework.security
  spring-security-test
  test

示例代碼如下:

@SpringBootTest
@RunWith(SpringRunner.class)
@AutoConfigureMockMvc
@WithMockUser(username = "admin", password = "admin")
public class ControllerTest {

  @Autowired
  protected MockMvc mockMvc;

  @Test
  void contextLoads() {
  }
}

注:@RunWith(SpringRunner.class)表示當(dāng)前測試使用org.springframework.test.context.junit4.SpringRunner類來執(zhí)行,最新的SpringBoot版本中已經(jīng)全面啟用junit5,不推薦使用junit4.SpringRunner,因為未經(jīng)過內(nèi)部學(xué)習(xí)與測試,未在生產(chǎn)項目中使用。

真實環(huán)境測試

為了減少學(xué)習(xí)與溝通的成本,之前,所有的測試規(guī)定都在MOCK環(huán)境下,使用MockMVC進(jìn)行api測試。

雖然MOCK環(huán)境能解決大部分的問題,并且可以在不啟動Server的情況下直接進(jìn)行測試,但在某些場景下,仍需要真實環(huán)境下的HTTP服務(wù)與請求測試。

啟用Spring Security后,MockMVC是直接測試控制器,并非在真實的HTTP服務(wù)器下進(jìn)行測試,MOCK環(huán)境中使用的是MockHttpSession,這不是標(biāo)準(zhǔn)的Session實現(xiàn),沒有加入對COOKIE的支持,所以在測試安全模塊時,無法像瀏覽器一樣測試COOKIE等認(rèn)證信息。

spring mockmvc doesn't contain cookies - stackoverflow

去StackOverflow上也沒有解決方案,答案推薦使用TestRestTemplate+真實的服務(wù)器環(huán)境進(jìn)行單元測試。

將webEnvironment配置為SpringBootTest.WebEnvironment.RANDOM_PORT,即表示當(dāng)前測試在一個隨機(jī)端口的真實Web環(huán)境下運行。

@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
class AuthControllerTest {
  @Autowired
  private TestRestTemplate restTemplate;
}

測試時使用TestRestTemplate進(jìn)行網(wǎng)絡(luò)請求的發(fā)送,真實模擬Web服務(wù)器環(huán)境。

示例代碼如下:

logger.debug("3: 測試用戶名密碼正確");
username = RIGHT_USERNAME;
password = RIGHT_PASSWORD;
response = this.restTemplate
    .withBasicAuth(username, password)
    .getForEntity(CONFIG_LOGIN, Void.class);

logger.debug("斷言: 狀態(tài)碼為200");
assertThat(response.getStatusCode().value()).isEqualTo(HttpStatus.OK.value());

logger.debug("獲取 response 的 Set-Cookie 信息,并斷言");
String setCookie = response.getHeaders().getFirst(HttpHeaders.SET_COOKIE);
assertThat(setCookie).isNotNull();

總結(jié)

兩個各有優(yōu)點,之前我們一直使用簡單方便的Mock環(huán)境進(jìn)行測試,但當(dāng)我們有一天,發(fā)現(xiàn)這個Mock環(huán)境測試下的MockHttpSession無法滿足需求的時候,我們開始探索其他的測試方案。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


文章標(biāo)題:SpringSecurity測試實戰(zhàn)
本文網(wǎng)址:http://news.spvevtbd.cn/article/jgchcc.html

其他資訊

在線咨詢
服務(wù)熱線
服務(wù)熱線:028-86922220
TOP