PageObject分離E2E測(cè)試

PageObject

It should allow a software client to do anything and see anything that a human can

  • PageObject到底是個(gè)啥

將針對(duì)Page的所有操作進(jìn)行統(tǒng)一封裝熄阻,如: 輸入框中輸入內(nèi)容、點(diǎn)擊按鈕等

  • E2E的幾個(gè)痛點(diǎn)

    • 前端調(diào)整引起元素定位不到,如

    登錄頁(yè)面的密碼輸入框的id被程序員不小心給刪除了袜茧,執(zhí)行E2E測(cè)試過(guò)程中就會(huì)無(wú)法定位到密碼輸入框撵幽,即使有錯(cuò)誤提示梯捕,你就要找到所有密碼輸入框并修改密碼輸入框元素定位

    • 相同的頁(yè)面操作,要在不同的地方使用从诲,寫(xiě)N次种蝶,代碼冗余契耿,很不利于后期維護(hù)

    用戶(hù)登錄,這樣的操作是最常見(jiàn)的螃征。但我們經(jīng)常會(huì)出現(xiàn)在每個(gè)需要登錄的地方搪桂,寫(xiě)一遍用戶(hù)登錄

  • 使用PageObject都可以解決

    • 如果元素定位不到,只需要修改對(duì)應(yīng)的頁(yè)面的PageObject就好盯滚,一處改動(dòng)踢械,關(guān)聯(lián)的地方都OK了
    • 將相同的頁(yè)面操作,進(jìn)行抽離至PageObject中魄藕,大大減少代碼的冗余

下面我們看一個(gè)實(shí)踐: 如何將頁(yè)面進(jìn)行PageObject抽離

分離PageObject

原始代碼

public class ExampleInstrumentedTest {


    public static final String STRING_TO_BE_TYPED_EMAIL = "EspressoDemo@mail.com";
    public static final String STRING_TO_BE_TYPED_EMAIL_PASSWORD = "123456";

    @Rule
    public ActivityTestRule<LoginActivity> mActivityRule = new ActivityTestRule<>(
            LoginActivity.class);

    @Test
    public void testAttemptLogin() {
        // Type text and then press the button.
        onView(withId(demo.test.espressodemo.R.id.email))
                .perform(typeText(STRING_TO_BE_TYPED_EMAIL), closeSoftKeyboard());
        onView(withId(demo.test.espressodemo.R.id.email))
                .check(matches(withText(STRING_TO_BE_TYPED_EMAIL)));

        onView(withId(demo.test.espressodemo.R.id.password))
                .perform(typeText(STRING_TO_BE_TYPED_EMAIL_PASSWORD), closeSoftKeyboard());
        onView(withId(demo.test.espressodemo.R.id.password))
                .check(matches(withText(STRING_TO_BE_TYPED_EMAIL_PASSWORD)));

        onView(withId(demo.test.espressodemo.R.id.email_sign_in_button))
                .perform(click());

    }
}

testAttemptLogin中可以看出測(cè)試流程是這樣

  • 第一步: R.id.email輸入內(nèi)容STRING_TO_BE_TYPED_EMAIL内列,再驗(yàn)證輸入內(nèi)容是否為STRING_TO_BE_TYPED_EMAIL
  • 第二步: R.id.password輸入內(nèi)容STRING_TO_BE_TYPED_EMAIL_PASSWORD,再驗(yàn)證輸入內(nèi)容是否為STRING_TO_BE_TYPED_EMAIL_PASSWORD
  • 第三步: 點(diǎn)擊R.id.email_sign_in_button按鈕

這是一個(gè)最常見(jiàn)的E2E測(cè)試的編寫(xiě)方式背率,這樣的編寫(xiě)方式话瞧,明顯就一步一步進(jìn)入了我們上面提的 E2E的幾個(gè)痛點(diǎn)

分離手術(shù)

  • 提取登錄PageObject: LoginPageObject
public class LoginPageObject {

    public static void inputEmail(String email){
        onView(withId(demo.test.espressodemo.R.id.email))
                .perform(typeText(email), closeSoftKeyboard());
        onView(withId(demo.test.espressodemo.R.id.email))
                .check(matches(withText(email)));
    }

    public static void inputPassword(String password){
        onView(withId(demo.test.espressodemo.R.id.password))
                .perform(typeText(password), closeSoftKeyboard());
        onView(withId(demo.test.espressodemo.R.id.password))
                .check(matches(withText(password)));
    }

    public static void clickLogin(){
        onView(withId(demo.test.espressodemo.R.id.email_sign_in_button))
                .perform(click());
    }
}
  • 使用登錄PageObject來(lái)實(shí)現(xiàn)之前的測(cè)試功能
public class ExampleInstrumentedTest {
    public static final String email = "EspressoDemo@mail.com";
    public static final String password = "123456";

    @Rule
    public ActivityTestRule<LoginActivity> mActivityRule = new ActivityTestRule<>(
            LoginActivity.class);

    @Test
    public void testAttemptLogin() {
        // Type text and then press the button.

        LoginPageObject.inputEmail(email);

        LoginPageObject.inputPassword(password);

        LoginPageObject.clickLogin();

    }
}

至此,PageObject已經(jīng)分離完成寝姿,我們肯定不會(huì)到此就結(jié)束的交排,再把測(cè)試數(shù)據(jù)進(jìn)行分離,便于整體數(shù)據(jù)的維護(hù)

  • 提取用戶(hù)數(shù)據(jù): UserInfo
public class UserInfo {
    public static final String email = "EspressoDemo@mail.com";
    public static final String password = "123456";

}
  • 再次調(diào)整測(cè)試代碼
public class ExampleInstrumentedTest {

    @Rule
    public ActivityTestRule<LoginActivity> mActivityRule = new ActivityTestRule<>(
            LoginActivity.class);

    @Test
    public void testAttemptLogin() {
        // Type text and then press the button.

        LoginPageObject.inputEmail(UserInfo.email);

        LoginPageObject.inputPassword(UserInfo.password);

        LoginPageObject.clickLogin();

    }
}

走到這里饵筑,我們會(huì)發(fā)現(xiàn)埃篓,現(xiàn)在的測(cè)試很清晰,也很好維護(hù)

測(cè)試僅有步驟

  • Login輸入郵箱地址
  • Login輸入密碼
  • Login點(diǎn)擊登錄按鈕

有沒(méi)有發(fā)現(xiàn)根资,這樣的測(cè)試架专,更符合業(yè)務(wù).

總結(jié)

  • 使用PageObject模型后,測(cè)試代碼更加便于維護(hù)嫂冻,大大增加了可讀性,減少了冗余代碼
  • PageObject就是將頁(yè)面的操作行為胶征,進(jìn)行單獨(dú)分離和維護(hù)塞椎,統(tǒng)一管理
  • PageObject/測(cè)試數(shù)據(jù)/測(cè)試腳本的關(guān)系


    關(guān)系圖
  • 完整代碼: https://github.com/aimer1124/EspressoDemo

參考

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末桨仿,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子案狠,更是在濱河造成了極大的恐慌服傍,老刑警劉巖钱雷,帶你破解...
    沈念sama閱讀 221,695評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異吹零,居然都是意外死亡罩抗,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)灿椅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)套蒂,“玉大人,你說(shuō)我怎么就攤上這事茫蛹〔俚叮” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,130評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵婴洼,是天一觀的道長(zhǎng)骨坑。 經(jīng)常有香客問(wèn)我,道長(zhǎng)柬采,這世上最難降的妖魔是什么欢唾? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,648評(píng)論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮粉捻,結(jié)果婚禮上礁遣,老公的妹妹穿的比我還像新娘。我一直安慰自己肩刃,他們只是感情好亡脸,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,655評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著树酪,像睡著了一般浅碾。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上续语,一...
    開(kāi)封第一講書(shū)人閱讀 52,268評(píng)論 1 309
  • 那天垂谢,我揣著相機(jī)與錄音,去河邊找鬼疮茄。 笑死滥朱,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的力试。 我是一名探鬼主播徙邻,決...
    沈念sama閱讀 40,835評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼畸裳!你這毒婦竟也來(lái)了缰犁?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,740評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎帅容,沒(méi)想到半個(gè)月后颇象,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,286評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡并徘,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,375評(píng)論 3 340
  • 正文 我和宋清朗相戀三年遣钳,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片麦乞。...
    茶點(diǎn)故事閱讀 40,505評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蕴茴,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出姐直,到底是詐尸還是另有隱情荐开,我是刑警寧澤,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布简肴,位于F島的核電站晃听,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏砰识。R本人自食惡果不足惜能扒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,873評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望辫狼。 院中可真熱鬧初斑,春花似錦、人聲如沸膨处。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,357評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)真椿。三九已至鹃答,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間突硝,已是汗流浹背测摔。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,466評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留解恰,地道東北人锋八。 一個(gè)月前我還...
    沈念sama閱讀 48,921評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像护盈,于是被迫代替她去往敵國(guó)和親挟纱。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,515評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理腐宋,服務(wù)發(fā)現(xiàn)紊服,斷路器檀轨,智...
    卡卡羅2017閱讀 134,701評(píng)論 18 139
  • ¥開(kāi)啟¥ 【iAPP實(shí)現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開(kāi)一個(gè)線程,因...
    小菜c閱讀 6,444評(píng)論 0 17
  • 1围苫、不安全的隨機(jī)數(shù)生成,在CSRF TOKEN生成撤师、password reset token生成等剂府,會(huì)造成toke...
    nightmare丿閱讀 3,705評(píng)論 0 1
  • Google Android Templates 緣由:從eclipse時(shí)代到“死丟丟”時(shí)代腺占,一直存在一個(gè)我未曾深...
    Clone丶記憶閱讀 3,546評(píng)論 4 17
  • 生老病死,自然法則痒谴;隨心隨性衰伯,自律自由。世間萬(wàn)物积蔚,唯天獨(dú)大意鲸!
    絕頂紳士閱讀 243評(píng)論 0 1