第15章 シンプルなフォーム
この作品はAIを使って翻訳されている。ご意見、ご感想をお待ちしている:translation-feedback@oreilly.com
前章の終わりで、 ビューの検証処理部分に重複が多すぎると指摘した。 Djangoはユーザ入力の検証やエラーメッセージの表示をフォームクラスで行うよう推奨している。
テストを使ってDjangoフォームの仕組みを探り、 その後ビューをリファクタリングしてフォームを活用する。 この過程で、単体テストと機能テストを組み合わせることで、 回帰から守られることを確認していこう。
検証ロジックをフォームに移す
ヒント
Djangoでは複雑なビューはコードの臭いである。 そのロジックの一部はフォームに移せないか? あるいはモデルクラスのカスタムメソッドに移せないか? あるいは(おそらく最善策として)ビジネスロジックを表すDjango以外のモジュールに移せないか?
Djangoではフォームにはいくつかの強力な機能がある:
-
これらはユーザ入力をプロセスし、エラーの有無を検証できる。
-
テンプレート内で HTML 入力要素やエラーメッセージのレンダリングに使える。
-
また、後で見るように、一部のフォームはデータをデータベースに保存することもできる。
全てのフォームでこれら3つの超能力を全て使う必要はない。独自のHTMLを記述したり、独自の保存処理を行ったりする方が好ましい場合もある。しかし検証ロジックを保持する場所としては最適だ。
単体テストでフォーム API を探る
単体テストを使ってフォームを少し試してみよう。完全な解決策に向けて段階的に進め、フォームを初めて見る人にも理解できる速度で導入していくつもりだ。
まずフォームの単体テスト用ファイルを追加し、フォームのHTMLを確認するだけのテストから始める:
src/リスト/テスト/テスト_フォーム.py (ch15l001)
fromdjango.testimportTestCasefromlists.formsimportItemFormclassItemFormTest(TestCase):deftest_form_renders_item_text_input(self):form=ItemForm()self.fail(form.as_p())
form.as_p() フォームをHTMLとしてレンダリングする。この単体テストでは、探索的なコーディングのためにself.failを使用している。manage.py shellセッションを使うことも可能だが、変更のたびにコードを再読み込みする必要がある。
最小限のフォームを作成しよう。これは基本クラスForm を継承し、item_text という単一のフィールドを持つ:
src/リスト/forms.py (ch15l002)
fromdjangoimportformsclassItemForm(forms.Form):item_text=forms.CharField()
これで自動生成されるフォームHTMLの 外観を示すエラーメッセージが表示される:
AssertionError: <p>
<label for="id_item_text">Item text:</label>
<input type="text" name="item_text" required id="id_item_text">
[...]
</p>
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Read now
Unlock full access