close
網站架設
這兩個指令會產生可執行的 composer.phar ,然後可以直接執行。想要用全域的體例執行需要再下這個指令:(以下會以全域的體式格局當範例)
它做了什麼上面都有寫,這部門就不贅述了。不過有兩個處所我個人習慣上會調劑:
- .gitignore 它會新增一行,那行我會刪除
- 複製檔案 cp ./tests/_output/.gitignore ./tests/_support/_generated/
初始化完後,就能夠開始履行了
需要注意的是,上面三個都是互有聯系關系,聯系關系以下:
- composer.json 檔裡,利用 PSR4 ,設定為 "HelloWorld\\": "src" ,代表 HelloWorld 的 Namespace 會進來 src 找
- Number.php 天然就是放在 src 下面了
設定好以後,下 composer dump-autoload 會重新產生 autoload 劃定規矩檔。只要程式一最先有載入 vendor/autoload.php ,以後就能夠在任何處所 new \HelloWorld\Number() 了。
Codeception 在起頭執行前,會先載入 _bootstrap.php 做初始化,如載入 autoload.php 就是一個可以做的事,它的樣板檔也是這麼說的:
目次佈局:(注意 Number.php 檔案位置)
有看到版號的話,恭喜你,環境建好了!
Codeception 可以整合的功能很多,不外今天就先把單位測試寫好就好。將來測試會一直加上去,但對開辟者而言,只要下執行指令,它就會把所有測試都所有跑過,並產生報表說測試有沒有經由過程,很是處所便。
這個指令會產生 composer.json 、 composer.lock 兩個檔案與 vendor 目錄。今朝的佈局以下:
再來先把昨天的 Number 種別加到專案裡,程式以下: (注意要加 namespace)
這邊诠釋一下:
- Function 名稱習慣上會寫的很白話,猶如上面所看到的,因為測試效果看到的都是 function 名稱占多數。
- 測試套件通常會供給許多 assert 供選擇,上例是最經常使用的 assertEquals() ,判定兩個值是不是相等。
執行一下,若是看到下面這張圖,代表你第一個測試寫成功了。
建置環境
$this->assertTrue($actual) 講白話一點指的是:假定 $actual 這個變數的內容是 true ,若是 false 的話,假定就錯了。以這個例子,這個假定是永久准確的。我們來看履行後果:

假如看到跟上面一樣成績的話,恭喜你,第一個測試寫好了!
安裝好後,建個空目次,進去下指令就可以安裝 Codeception 了:
此中 composer.json 是定義這個專案(也就是這個目錄)所需要安裝的套件為何,可以使用 composer require <vendor>/<package> 的指令或手動點竄 JSON 新增。 --dev 參數則是標識表記標幟此套件是開發階段才會利用。不行能上線了才在測試,一定是開辟的時候測,所以 Codeception 會加 --dev 參數。
當一切就绪時,可以下這個指令確認是否有安裝成功:
它會提醒說,有新增一個測試檔在 tests/unit/NumberTest.php 這裡。裡面預設有一個叫 testMe() 的方法,我們在裡面加一個一定會過的測試看看:
起首要設定 Namespace , PHP 的 namespace 可使用 composer.json 設定,設定檔範例以下:
再往返到方才的測什麼都能過的測試檔 NumberTest.php ,我們來加第一個真實的測試:
初始化目次結構
第一次跑的成果以下:

固然,我們還沒入手下手寫測試呢!新增測試的方式以下:
測試框架
昨天有寫出一些陽春的測試程式。雖然夠用,但假如要做進階的測試方式或是分析測試過程,明顯要實作出更多功能才能相符需求。但不用擔心,開源的世界裡有很是多先輩,實作出專為測試利用的框架,讓我們寫測試可以輕鬆很多。
開源專案用起來開心的話,無妨去 GitHub 按個 Star 撐持一下吧!
肯定指令可以操作後,接著下這個指令,就會幫你把一開始的目次都初始化好:
正式寫測試程式
文章標籤
全站熱搜