OAuth 2.0 單元測試解決方案

為什么需要單元測試

單元測試擁有保證代碼質(zhì)量、盡早發(fā)現(xiàn)軟件 Bug把鉴、簡化調(diào)試過程、促進(jìn)變化并簡化集成儿咱、使流程更靈活等優(yōu)勢庭砍。單元測試是針對代碼單元的獨立測試,核心是“獨立”混埠,優(yōu)勢來源也是這種獨立性怠缸,而所面臨的不足也正是因為其獨立性:既然是“獨立”,就難以測試與其他代碼和依賴環(huán)境的相互關(guān)系钳宪。單元測試與系統(tǒng)測試是互補而非代替關(guān)系揭北。單元測試的優(yōu)勢,正是系統(tǒng)測試的不足吏颖,單元測試的不足搔体,又恰是系統(tǒng)測試的優(yōu)勢。不能將單元測試當(dāng)做解決所有問題的萬金油半醉,而需理解其優(yōu)勢與不足疚俱,揚長避短,與系統(tǒng)測試相輔相成缩多,實現(xiàn)測試的最大效益计螺。

OAuth2 系統(tǒng)單元測試?yán)щy

  • 接口測試依賴于 UPMS (用戶權(quán)限管理),無法做到解耦獨立

  • spring-security-test 模塊未提供相關(guān)標(biāo)準(zhǔn)實現(xiàn)

  • 場景復(fù)雜既要包含無狀態(tài) token 調(diào)用瞧壮,又要保證上線文傳遞業(yè)務(wù)

解決方案

參考 @WithMockUser 登馒,在 Mock 攔截器中自動執(zhí)行相關(guān)的增強(token 獲取)咆槽,并通過擴(kuò)展 WithSecurityContextFactory 實現(xiàn)上下文 token 的傳遞陈轿。具體可以參考源碼 pig-common-test[1]

引入依賴

<dependency>
  <groupId>com.pig4cloud</groupId>
  <artifactId>pig-common-test</artifactId>
  <version>${last.version}</version>
  <scope>test</scope>
</dependency>

單元測試 Controller 接口

  • 指定認(rèn)證中心接口
配置在 test/resources/application.yml
security:
  oauth2:
    client:
      access-token-uri: http://pig-gateway:3000/oauth/token
  • 模擬測試 controller 接口
@RunWith(SpringRunner.class)
@SpringBootTest
public class SysLogControllerTest {

 private MockMvc mvc;

 @Autowired
 private WebApplicationContext applicationContext; // 注入WebApplicationContext

 @Before
 public void setUp() {
  this.mvc = MockMvcBuilders.webAppContextSetup(applicationContext).build();
 }

 @Test
 @SneakyThrows
 @WithMockOAuth2User
 public void testMvcToken() {
  mvc.perform(delete("/log/1").with(token())).andExpect(status().isOk());
 }
}

模擬測試 FeignClient 傳遞 token

直接注入 FeignClient 實現(xiàn)即可 使用 @WithMockOAuth2User 注解測試類即可

WithMockOAuth2User 屬性說明

  • 當(dāng)前用例獲取 token 使用的用戶名
String username() default "admin";
  • 當(dāng)前用例獲取 token 使用的密碼
String password() default "123456";

寫在最后
源碼參考 pig-common-test 模塊
目前僅在 pig 2.10 做了實現(xiàn),理論支持低版本,直接 install 此模塊即可

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末麦射,一起剝皮案震驚了整個濱河市蛾娶,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌潜秋,老刑警劉巖蛔琅,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異峻呛,居然都是意外死亡罗售,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進(jìn)店門钩述,熙熙樓的掌柜王于貴愁眉苦臉地迎上來寨躁,“玉大人,你說我怎么就攤上這事牙勘≈翱遥” “怎么了?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵方面,是天一觀的道長放钦。 經(jīng)常有香客問我,道長恭金,這世上最難降的妖魔是什么操禀? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮蔚叨,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘辙培。我一直安慰自己蔑水,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布扬蕊。 她就那樣靜靜地躺著搀别,像睡著了一般。 火紅的嫁衣襯著肌膚如雪尾抑。 梳的紋絲不亂的頭發(fā)上歇父,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天,我揣著相機(jī)與錄音再愈,去河邊找鬼榜苫。 笑死,一個胖子當(dāng)著我的面吹牛翎冲,可吹牛的內(nèi)容都是我干的垂睬。 我是一名探鬼主播,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼驹饺!你這毒婦竟也來了钳枕?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤赏壹,失蹤者是張志新(化名)和其女友劉穎鱼炒,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蝌借,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡昔瞧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了骨望。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片硬爆。...
    茶點故事閱讀 40,680評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖擎鸠,靈堂內(nèi)的尸體忽然破棺而出缀磕,到底是詐尸還是另有隱情,我是刑警寧澤劣光,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布袜蚕,位于F島的核電站,受9級特大地震影響绢涡,放射性物質(zhì)發(fā)生泄漏牲剃。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一雄可、第九天 我趴在偏房一處隱蔽的房頂上張望凿傅。 院中可真熱鬧,春花似錦数苫、人聲如沸聪舒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽箱残。三九已至,卻和暖如春止吁,著一層夾襖步出監(jiān)牢的瞬間被辑,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工敬惦, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留盼理,地道東北人。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓俄删,卻偏偏與公主長得像榜揖,于是被迫代替她去往敵國和親勾哩。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,691評論 2 361