在這一章里,我們將看到Yii2怎樣幫助我們創建web應用。示例雖然很簡單,但整個過程都符合軟件工程思想。我們將完成應用開發的每一個步驟,并且每一步都會根據權威書籍中的實踐來進行:
北京網站制作公司哪家好,找創新互聯建站!從網頁設計、網站建設、微信開發、APP開發、成都響應式網站建設公司等網站項目制作,到程序開發,運營維護。創新互聯建站于2013年創立到現在10年的時間,我們擁有了豐富的建站經驗和運維經驗,來保證我們的工作的順利進行。專注于網站建設就選創新互聯建站。創建領域模型:這本書解釋了領域驅動,Tackling Complexity in the Heart of Software, Eric Evans, Addison-Wesley Professional
設置測試裝置:我們遵照驗收測試驅動實踐,Growing Object-oriented Software, Guided by Tests, Steve Freeman and Nat Pryce, Addison-Wesley Professional
設置開發流水線
持續交付:Reliable Software Releases through Build, Test, and Deployment Automation, Jez Humble and David Farley, Addison-Wesley Professional
持續集成:Improving Software Quality and Reducing Risk, Paul M. Duvall, Steve Matyas, and Andrew Glover, Addison-Wesley Professional
紅-綠-重構 開發循環:深度解釋,請參考下列圖書:
Clean Code:A Handbook of Agile Software Craftsmanship, Robert Martin, Prentice Hall
Test-Driven Development by Example, Kent Beck, Addison-Wesley Professional
部署和手工測試:這符合持續交付,并且這些步驟也是必不可少的
保持專注。
設計階段貫穿整本書,在使用示例應用的時候,我們需要注意實際需求。在這個小節,我們將定義整個示例的場景。
任務假設我們有一個小的商業應用,要對外提供一些服務。我們有一些客戶,他們有一些數目巨大的賬目記錄在紙面上,用商業卡片管理非常不方便。因此,我們需要用自動化的方式把這些檔案管理起來。
首先,我們需要一些增刪查改(CRUD)界面進行記錄管理,為客戶展示最核心的屬性。
很明顯,我們的業務和客戶可能會隨著時間的推移而增長、變化,因此我們的應用也應該隨之變化。在一開始,我們就應該為可能的變化做好準備。
本著吃自己狗食的原則(譯注:微軟在1998年提出),既然自己開發的系統自己要使用,那這個系統最好保證是高質量的。
領域模型設計很明顯,我們將在應用中處理客戶模型。在“customer”和“client”兩個詞中,我們覺得“customer”更為貼切。
一個客戶(customer)是一個人,他至少具有姓名、地址、電子郵件,以及電話號碼等屬性。我們為客戶提供一個服務,按小時統計,并根據合約支付這段時間產生的費用。這就是我們在第一次迭代設計中打算解決的問題。
我們假設每位客戶都是單個的人,因此我們不用處理公司,有多個聯系人的情況。姓名是一個復雜的結構,如果我們深入細節,有敬語、職務、昵稱、中間名、姓等屬性需要考慮。但在這個應用中,我們真正感興趣的并不是客戶的姓名,我們只是需要用姓名來識別一個客戶。因此,我們將簡單的使用一個文本行來表示,允許我們按任何格式來寫入姓名。地址同樣可以是一個復雜的結構,這次我們打算用一個結構來描述,而不再是一個簡單的文本行。這是因為我們需要通過地址來實現以下兩件事情。
進行一些統計,例如在一個特定的城市,有多少個客戶
遵照不同的文化背景,正確地生成郵寄地址
因此,我們決定采用下面的結構:
用途(例如:賬單地址、購物地址、家庭地址、工作地址)
國家
州,國家下級的區域,比如美國
城市
街道
建筑物
部門/辦公室
收件人姓名
郵政編碼
我們應該注意到,一個地址能代表一個部門、郵箱、辦公室、組織中的雇員,甚至是整個建筑。同樣,一個客戶也可以多個地址。
電話這個實體具有以下屬性:
用途(個人或工作)
號碼
一個客戶可能有幾個電話號碼,通過用途字段區分。
除了姓名、地址、電話這個實體之外,我們的職員需要通過一種途徑對客戶進行自由的描述。這里我們簡化了姓名屬性。然后,我們加入生日、電子郵件屬性,當然,一個客戶可以有多個電子郵件。
我們先停一下。
我們現在能畫出客戶模型的完整聚合圖了,如下圖所示:
根據Eric Evans的《領域驅動設計》,客戶是一個實體(Entity),也就是說,是一個狀態可以改變的對象,因此我們要關心它在整個系統中的一致性。而其它部分是值對象(Value Object),意味著初始創建后,狀態不會改變的對象,因此他們是可以完全互換的。
為了簡化處理,我們不再詳細描述商業上是如何處理客戶的,我們不打算在這本書中涵蓋它。無論如何,讓我們把注意力回到我們為客戶提供的一系列服務中來,維護這些記錄將會很有用。我們將在后面的章節用到這個模型。
目標特性讓我們來執行一個特定的任務。考慮到有的人給我們打電話(假如我們已經識別出號碼),我們想獲取呼入者的所有詳細信息。在應用中,如果這個號碼沒有找到關聯的人,那我們就知道他并不是我們的客戶。如果找到關聯人,我們至少可以直接用他的姓名跟他打招呼,這是很好的客戶服務。
我們應該理解數據庫查詢,我們需要一個途徑可以插入數據,有可能還需要編輯和刪除它。因此,我們第一次開發迭代的特性包含以下內容:
將客戶信息插入數據庫
在數據庫中編輯客戶信息
從數據庫中刪除客戶信息
根據電話號碼從數據庫中查詢客戶信息
構造通用的數據庫查詢并不是我們的目標,我們僅僅需要根據一個電話號碼進行查詢。
讓我們開始吧。
初始準備一直到本書結束,我們將在接下來的章節中討論同一個應用,因此準備工作只需要做這一次。
下載示例代碼:Packt的網站上可以下載你購買過圖書的示例代碼,地址是http://www.packtpub.com,如果你已經購買了這本書,請訪問http://www.packtpub.com/support,注冊后會直接將文件通過電子郵件發送給你。
配置項目管理我們要開發的應用,從本質上說,是一個客戶關系管理系統(CRM)。因此,我們首先創建一個名為 crmapp 的目錄。
請注意,正本書中,通過命令行調用的示例,都假定你當前目錄為crmapp目錄。
Yii2推薦使用包管理器Composer進行安裝,因此我們就來使用這個工具。你可以去閱讀Composer的完整文檔了解詳細的細節,我們在這里準備了一個簡短的說明:
所有通過Composer安裝的包,都會存放在項目路徑下,一個名為vendor的子目錄中。
與Composer相關的數據,所有依賴和其它信息,都保存在名為composer.json的清單文件中,位于項目根目錄下。只要你在這個文件中申明了依賴,你就能在任何時候安全的刪除vendor目錄,并在調用php composer.phar install 或 php composer.phar update時完全重建。
Composer的文檔描述了一個獲取composer.phar的方法:
curl-sShttps://getcomposer.org/installer|php
當然,如果你的PATH路徑中如果沒有CURL,你也可以直接去Composer的官方網站https://getcomposer.org/ 直接下載PHAR文件。(譯注:如果是windows環境,推薦直接下載一個Composer的安裝包,安裝完成后,添加到PATH目錄,以后就可以直接使用composer <command>進行調用,而不使用php composer.phar <command>,更為方便)。
我們準備好后,就可以按下面的格式執行命令了:
phpcomposer.phar<command>
假定你會使用版本控制系統來管理代碼,本書的代碼使用Git(http://git-scm.com/)進行管理。
準備階段快速指引:
mkdircrmapp cdcrmapp curl-sS|php gitinit 配置測試工具
正如我們在本章的開始部分所說,我們將遵從測試優先的開發實踐來進行驗收測試。這樣做的原因如下:
我們想檢查應用是否能正常工作,又不想使用乏味的人工測試
我們還沒有深度的單元測試需求,因為我們目前主要的工作只是把已經存在的組件裝配在一起,因此,通過對UI進行端對端的驗收測試最為簡單可行
如果我們關心用戶特性請求的實現情況,我們需要一些形式的驗收測試。
Yii2內置支持Codeception測試框架,官方站點是 http://codeception.com/。我們不會在本身中直接使用它,但是 yii2-codeception(https://github.com/yiisoft/yii2-codeception)提供了一些輔助類,來集成到Yii框架中。
讓我們來申明,我們需要在項目中使用 Codeception,執行下面的命令:
phpcomposer.pharrequire"codeception/codeception:*"
稍等片刻,直到Composer執行完成。
目前,composer.json文件的內容是:
{ "require":{ "codeception/codeception":"*", } }
命令 php composer.phar require <包名:版本> 只是一個輔助方法,將require塊插入到清單文件中,并調用update命令。
當然,我也需要將Yii2同樣作為依賴加入,但在這之前,讓我們先干一件事情。
正如我們看到的,Codeception已經存在于 ./vendor/bin/codecept 目錄中了。這個路徑敲起來比較長,在POSIX兼容的shell中,比如bash,允許我們使用下面的方式來進行簡化:
aliascept="./vender/bin/codecept"
這樣做更好。在本章余下的部分,我們都假定你已經執行了上面這條命令。
Codeception是一個復雜的系統,所以我們需要依賴它自己內建的命令。沒必要深入Codeception的內部細節,我們只是簡單實用就可以了。執行下面的命令:
ceptbootstrap
這將為Codeception生成一個tests目錄,并進行配置。
現在,讓我們創建一個傻瓜型的驗收測試,用以檢查我們的測試工具。
ceptgenerate:ceptacceptanceSmokeTest
這個命令將生成 SmokeTestCept.php,位于 tests/acceptance 目錄下。當我們打開這個文件,我們將看到如下代碼(根據Codeception版本,代碼可能略有不同):
$I=newAcceptanceTester($scenario); $I->wantTo(\'performactionsandseeresult\');
AcceptanceTester是一個可以模仿瀏覽器后的真實用戶,對應用進行測試的類。Codeception同時也提供 CodeGuy 用以進行單元測試,提供 TestGuy 進行功能測試,在后面我們才會用到。
當我們調用 AcceptanceTester.wantTo("do something")時,我們只是為下面的測試行為創建了一個標題(用雙引號括起來的)。
讓我們修改一下代碼,加入冒煙測試的功能,對我們的首頁進行測試:
$I=newAcceptanceTester($scenario); $I->wantTo(\'Seethatlandingpageisup\'); $I->amOnPage(\'/\'); $I->see(\'OurCRM\');
當我們訪問應用首頁的時候,我們希望看到有 Our CRM 這一行。假設我們應用中已經有那么一個標題存在了。
現在運行測試:
ceptrun
我們會看到失敗的信息,因為我們還沒有設置web服務器,處理 / 請求。這樣,到了該我們寫一些生產代碼來通過這個測試的時候了。然而,到目前而言,我們需要的還不是生產代碼,我們的基礎服務都還沒有建立起來。我們需要先建立發布機制。
配置發布流水線我們已經說過,編寫的web驗收測試會模擬真實用戶,在瀏覽器中打開應用,通過可視的UI進行交互。因此,我們現在需要做的是將應用整個部署到我們能運行驗收測試的機器。
提示:最常見的情況是,你決定開發和測試使用同一臺機器,這是錯誤的!別這么干。
很可能你的工作平臺和應用最終要運行的機器不是一樣的。參照已有數十年歷史的工業生產,這已經是一個持續不斷的問題了。當應用的生命周期預計是數年時,在不同環境的生產服務器上測試你的應用,你會面臨相似的集成問題。當然,這不是將打包好的軟件賣給用戶,這還是要簡便一些。在我們的案例中,我們假定一個單一的發布點只有一個固定web應用,因此,簡便性不是問題,可重復性測試才是問題。
最終,你的驗收測試將會包含以下幾個步驟:
將應用發布到測試服務器
在你的機器上運行驗收測試
當然,你可以在測試服務器上運行驗收測試。要這樣做,你只需要用localhost這個本地回路網絡接口來配置測試就可以了。然而,還是需要你安裝一些與測試服務器不相干的軟件。例如,如果你想全棧運行,使用Selenium進行瀏覽器內測試,你可能需要安裝一個web瀏覽器,Java運行時,虛擬幀緩沖軟件,并且這又需要安裝它們各自相關的軟件,這樣做非常費勁。最有效的做法是使用你自己的桌面環境,來運行web驗收測試。
提示:這當然不是在談論單元測試和功能測試。單元測試由于只與本身有關,應在有原始代碼的地方執行,完全不需要部署。功能測試,應在部署后的應用上測試,因為需要測試經過配置后的最終應用以及交互的正確性。
在任何案例中,理想化的方案是,你只需一個就像deploy這樣的簡單命令,就能完成以下功能:
訪問并啟動目標機器(特別是,當它是一個虛擬機實例的時候)
確保除應用外,環境是有效的
將當前代碼拷貝到目標機器
在目標機器上,配置剛拷貝過去的代碼的環境
啟動應用
你應該能在命令行中輸入deploy,并敲擊Enter鍵,完成上述的所有步驟。正如Martin Fowler在他的《持續集成》(http://martinfowler.com/articles/continuousIntegration.html)中所說,這對你來說小菜一碟。理想情況下,部署行為應該在你啟動驗收測試工具時自動完成。
在本書中,我們只關心最后兩步。因為我們開發的是PHP應用,只要目標機器上的web服務器在運行,”啟動應用“這一步就算已經完成了。
本書僅關注web應用開發,并不涉及系統管理,那是系統管理員的事。然而,在附錄A,”使用Vagrant進行部署設置“,我們準備介紹一個基于虛擬機的部署,同樣也很容易在任何桌面工作站上實現。你可以不必需要另外一臺物理機,就仍然能模擬現實世界的部署過程。如果你別無選擇,強烈推薦你讀讀。實際上,采用那里的描述,本身所有的代碼都準備好了。讓我們假設你有一個準備好的環境和deploy命令,為了簡化,我們同時假定每次運行驗收測試前,部署都會自動運行。部署的結果可以從你的機器通過一個簡單的URL進行訪問,驗收測試工具會將它作為應用的入口點。
現在,讓我們到Codeception的跟驗收測試相關的配置部分,打開文件 tests/acceptance.suite.yml,把入口URL加入到 modules.config.PhpBrowser.url 詞條中。假定你沒修改過這個文件,文件內容看起來應該像這樣:
class_name:AcceptanceTester modules: enabled: -PhpBrowser -WebHelper config: PhpBrowser: url:\'http://YOUR.APPLICATION.URL\'
(譯注:本機acceptance.suite.yml文件格式跟上面不同,不存在config項,url直接放在enabled的PhpBrowser下)
舉例來說,如果你用Apache的基于IP的虛擬主機技術來配置目標機器(https://httpd.apache.org/docs/2.2/vhosts/ip-based.html),modules.config.PhpBrowser.url 的值就應該像這樣:http://127.0.0.01:8000。
當我們改變配置,我們需要重建Codeception,執行下面的命令:
ceptbuild
不要忘記 cept 這個別名是我們自己創建的。實際運行的是 ./vendor/bin/codecept 文件。
如果你現在運行測試:
ceptrun
你應該可以看到如下輸出:
你會看到Codeception在 / 路由上顯示了一些東西,但還不是我們期望的。根據使用的Apache版本不同,可以是404錯誤或者403錯誤。如果你使用的其它Web服務器,可能顯示的另外的錯誤信息。無論如何,問題的根源很簡單,這就是我們需要在外界可訪問的web目錄中,加入index.php文件。
創建一個可見的web應用入口我們先做一個約定,可以被外部訪問到的目錄只有一個,命名為web,放在項目的根目錄下。例如,如果你的web服務器是Apache,應該把DocumentRoot指向web目錄。
因此,將下面的內容放在web目錄的index.php文件中:
OurCRM
是的,就是7個字符的文本文件。畢竟,這就是我們的驗收測試期望的所有內容了,正確嗎?
讓我們來運行測試:
ceptrun
我們得到了如下輸出:
現在,我們需要在項目中使用Yii2了,描述我們功能需求的方法,就是寫一個完整的端到端測試。
下一節 上一節
本文題目:【翻譯】Yii2第2章用Yii2創建自定義應用(第1部分)
鏈接地址:http://vcdvsql.cn/article8/chsiop.html
成都網站建設公司_創新互聯,為您提供小程序開發、用戶體驗、外貿建站、外貿網站建設、定制開發、定制網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯