私の質問は、私のセットアップが現在、UI 受け入れテストを使用した BDD に関するベスト プラクティス アプローチに従っているかどうかに焦点を当てています。私は SpecFlow で WatiN を使用して UI 受け入れテストを作成し、アプリケーションを AppHarbor (.Net アプリケーションのサービスとしてのクラウド プラットフォーム) にデプロイしています。AppHarbor は、デプロイ時にユニット/統合テストを実行し、テストに合格した場合にのみサイトを公開します。そのため、最初に次のように基本的な失敗テストを作成することから始めました。
Scenario: Navigation to homepage
When I navigate to /
Then I should be on the application homepage
このテストに関連する手順では、WatiN を使用してブラウザーを開き、ビューのタイトル属性が "Welcome" に設定されていることを確認します。WatiN ブラウザーでテストする URL を決定するために環境をチェックしています。たとえば、開発中の場合は、ホームとして「http://localhost:49641/」に移動します。それ以外の場合は、「http://myappharborapp.com/」に移動します。
私の問題は、このアプリケーションを初めて展開する場合、ページまたはビューが実際には存在しないため、テストが失敗することです (サイトがまだ公開されていないため)。たとえば、後で「About」ページビューを追加し、失敗するテストを最初に書いた場合、これも失敗します。更新をプッシュすると、「About」ページがまだ存在しないため、テストは失敗します。
私の質問は次のとおりです。UI テストをどのように設定するかに関して、ベスト プラクティスに従っていませんか? どのような環境でも合格するために、これらのテストをどのように設定する必要がありますか?
どんな洞察も大歓迎です!