This project is no longer maintained and has been archived. |
データフィクスチャはテストするデータをデータベースに投入するためにモデルを通してテストデータの小さなセットをロードするための手段です。データフィクスチャはユニット/機能テストスィートでよく使われます。
インポートする
データフィクスチャのインポートはダンプと同じ簡単です。loadData()
メソッドを使うことができます:
Doctrine_Core::loadData('/path/to/data.yml');
上記のように個別のYAMLファイルを指定するか、もしくはディレクトリ全体を指定できます:
Doctrine_Core::loadData('/path/to/directory');
インポートしたデータを既存のデータに追加したい場合loadData()
メソッドの2番目の引数を使う必要があります。2番目の引数をtrueとして指定しない場合データはインポートされる前にパージされます。
パージする代わりに追加する方法は次の通りです:
Doctrine_Core::loadData('/path/to/data.yml', true);
ダンプする
データフィクスチャを書き始めるのを手助けするために多くの異なるフォーマットでフィクスチャファイルにデータをダンプできます。次のようんデータフィクスチャを1つの大きなYAMLファイルにダンプできます:
Doctrine_Core::dumpData('/path/to/data.yml');
もしくはオプションとしてすべてのデータを個別のファイルにダンプできます。モデルごとに1つのYAMLファイルをダンプするには次のようになります:
Doctrine_Core::dumpData('/path/to/directory', true);
実装
データフィクスチャを知ったので次のセクションで使われるフィクスチャの例をテストできるように、以前の章で利用してきたテスト環境で実装してみましょう。
最初にdoctrine_test
ディレクトリの中でfixtures
という名前のディレクトリを作成し内部でdata.yml
という名前のファイルを作成します:
$ mkdir fixtures $ touch fixtures/data.yml
データフィクスチャをロードするコードを含めるためにgenerate.php
スクリプトを修正する必要があります。generate.php
の一番下に次のコードを追加します:
// generate.php
// ... Doctrine_Core::loadData('fixtures');
書く
手作業でフィクスチャファイルを書いてアプリケーションでロードできます。下記のコードはサンプルのdata.yml
フィクスチャファイルです。データフィクスチャを複数のファイルに分割することもできます。Doctrineはすべてのフィクスチャファイルを読み込み解析し、すべてのデータをロードします。
次のいくつかの例に対して次のモデルを使用します:
// models/Resouce.php
class Resource extends Doctrine_Record { public function setTableDefinition() { $this->hasColumn('name', 'string', 255); $this->hasColumn('resource_type_id', 'integer'); }
public function setUp()
{
$this->hasOne('ResourceType as Type', array(
'local' => 'resource_type_id',
'foreign' => 'id'
)
);
$this->hasMany('Tag as Tags', array(
'local' => 'resource_id',
'foreign' => 'tag_id',
'refClass' => 'ResourceTag'
)
);
}
}
// models/ResourceType.php
class ResourceType extends Doctrine_Record { public function setTableDefinition() { $this->hasColumn('name', 'string', 255); }
public function setUp()
{
$this->hasMany('Resource as Resouces', array(
'local' => 'id',
'foreign' => 'resource_type_id'
)
);
}
}
// models/Tag.php
class Tag extends Doctrine_Record { public function setTableDefinition() { $this->hasColumn('name', 'string', 255); }
public function setUp()
{
$this->hasMany('Resource as Resources', array(
'local' => 'tag_id',
'foreign' => 'resource_id',
'refClass' => 'ResourceTag'
)
);
}
}
// models/ResourceTag.php
class ResourceTag extends Doctrine_Record { public function setTableDefinition() { $this->hasColumn('resource_id', 'integer'); $this->hasColumn('tag_id', 'integer'); } }
// models/Category.php
class BaseCategory extends Doctrine_Record { public function setTableDefinition() { $this->hasColumn('name', 'string', 255, array( 'type' => 'string', 'length' => '255' ) ); }
public function setUp()
{
$this->actAs('NestedSet');
}
}
class BaseArticle extends Doctrine_Record { public function setTableDefinition() { $this->hasColumn('title', 'string', 255, array( 'type' => 'string', 'length' => '255' ) );
$this->hasColumn('body', 'clob', null, array(
'type' => 'clob'
)
);
}
public function setUp()
{
$this->actAs('I18n', array('fields' => array('title', 'body')));
}
}
YAMLフォーマットでの例は次の通りです。[doc yaml-schema-files :name]の章でYAMLの詳細を読むことができます:
# schema.yml
Resource: columns: name: string(255) resource_type_id: integer relations: Type: class: ResourceType foreignAlias: Resources Tags: class: Tag refClass: ResourceTag foreignAlias: Resources
ResourceType: columns: name: string(255)
Tag: columns: name: string(255)
ResourceTag: columns: resource_id: integer tag_id: integer
Category: actAs: [NestedSet] columns: name: string(255)
Article: actAs: I18n: fields: [title, body] columns: title: string(255) body: clob
- NOTE
- すべての列のキーはすべてのYAMLデータフィクスチャにまたがってユニークでなければなりません。下記のtutorial、doctrine、help、cheatはすべてユニークです。
# fixtures/data.yml
Resource: Resource_1: name: Doctrine Video Tutorial Type: Video Tags: [tutorial, doctrine, help] Resource_2: name: Doctrine Cheat Sheet Type: Image Tags: [tutorial, cheat, help]
ResourceType: Video: name: Video Image: name: Image
Tag: tutorial: name: tutorial doctrine: name: doctrine help: name: help cheat: name: cheat
Resourceが持つTagsを指定する代わりにそれぞれのタグが関係するResourcesを指定できます。
# fixtures/data.yml
Tag: tutorial: name: tutorial Resources: [Resource_1, Resource_2] doctrine: name: doctrine Resources: [Resource_1] help: name: help Resources: [Resource_1, Resource_2] cheat: name: cheat Resources: [Resource_1]
入れ子集合用のフィクスチャ
入れ子集合のツリー用のフィクスチャファイルの書き方は通常のフィクスチャファイルの書き方と少し異なります。ツリーの構造は次のように定義されます:
# fixtures/data.yml
Category: Category_1: name: Categories # the root node children: Category_2: name: Category 1 Category_3: name: Category 2 children: Category_4: name: Subcategory of Category 2
# fixtures/data.yml |
Category: NestedSet: true Category_1: name: Categories # ...
もしくはchildrenキーワードを指定することでNestedSetのAPIを使用してデータをインポートします。
# fixtures/data.yml
Category: Category_1: name: Categories children: [] # ...
上記の方法を使わない場合入れ子集合レコード用にlft、rgtとレベルの値を手動で指定するのはあなた次第です。
国際化用のフィクスチャ
I18n
用のフィクスチャはカスタマイズできません。I18n
は動的に構築されるリレーションの通常の集合にすぎないからです:
# fixtures/data.yml
Article: Article_1: Translation: en: title: Title of article body: Body of article fr: title: French title of article body: French body of article
まとめ
データフィクスチャを書いてアプリケーションにロードできるようになりました。内在する[doc database-abstraction-layer :name]を学ぶために次の章に移動します。このレイヤーは以前検討したすべての機能に関係します。このレイヤーをORMから独立したものとして使うことができます。次の章ではDBALそのものの使い方を説明します。