Cakephp 3 - 单元测试验证默认



我目前正在尝试为以下模型编写单元测试:

<?php
namespace AppModelTable;
use AppModelEntityUser;
use CakeORMQuery;
use CakeORMRulesChecker;
use CakeORMTable;
use CakeValidationValidator;
/**
 * Users Model
 *
 * @property CakeORMAssociationHasMany $Comments
 * @property CakeORMAssociationBelongsToMany $Albums
 */
 class UsersTable extends Table
 {
    /**
     * Initialize method
     *
     * @param array $config The configuration for the Table.
     * @return void
     */
     public function initialize(array $config)
     {
       parent::initialize($config);
       $this->table('users');
       $this->displayField('id');
       $this->primaryKey('id');
       $this->addBehavior('Timestamp');
       $this->hasMany('Comments', [
           'foreignKey' => 'user_id'
       ]);
       $this->belongsToMany('Albums', [
          'foreignKey' => 'user_id',
          'targetForeignKey' => 'album_id',
          'joinTable' => 'users_albums'
       ]);
      }
/**
 * @Author: Mark van der Laan
 * @Date: 23-02-2016
 * @Description: Validating rules for the user model. Some additional, more complex validation rules are added.
 * @param CakeValidationValidator $validator Validator instance.
 * @return CakeValidationValidator
 */
public function validationDefault(Validator $validator)
{
    // id
    $validator
        ->integer('id')
        ->allowEmpty('id', 'create');
    // username
    $validator
        ->requirePresence('username', 'create')
        ->notEmpty('username')
        // Enabled, just in case that the username will be an email address
        ->email('username')
        ->add('username', [
            'length' => [
                'rule' => ['minLength', 7],
                'message' => 'Username needs to be at least 7 characters long!',
            ]
        ]);
    // password
    $validator
        ->requirePresence('password', 'create')
        ->notEmpty('password')
        ->add('password', [
            'length' => [
                'rule' => ['minLength', 7],
                'message' => 'Password needs to be at least 7 characters long!',
            ]
        ]);
    // sign_in_count
    $validator
        ->integer('sign_in_count')
        ->requirePresence('sign_in_count', 'create')
        ->notEmpty('sign_in_count');
    // ip address
    $validator
        ->allowEmpty('current_sign_in_ip')
        ->requirePresence('current_sign_in_ip', 'create')
        // Currently checking for both IPv4 and IPv6 addresses
        ->ip('current_sign_in_ip', 'both');
    // active
    $validator
        ->boolean('active')
        ->requirePresence('active', 'create')
        ->allowEmpty('active');
    return $validator;
}
/**
 * Returns a rules checker object that will be used for validating
 * application integrity.
 *
 * @param CakeORMRulesChecker $rules The rules object to be modified.
 * @return CakeORMRulesChecker
 */
public function buildRules(RulesChecker $rules)
{
    $rules->add($rules->isUnique(['username']));
    return $rules;
}
}

对我来说,测试验证默认方法很重要,我尝试使用以下代码片段执行此操作:

public function testValidationDefault()
{
    $data = ['username' => 'adminadmin@mixtureweb.nl',
             'password' => 'testtest123',
             'sign_in_count' => 0,
             'current_sign_in_ip' => '127.0.0.1',
             'active' => 'true'
            ];
    $this->assertTrue($this->Users->save($data));
    // $this->assertTrue($data);
}

当我尝试这样做时,这将抛出一个错误,指出我不应该将数组传递给 assertTrue 方法。因此,我试图找到示例,但我找不到任何东西。有没有人可以在其中找到如何单元测试验证规则的参考资料?(到目前为止,我在文档中找不到任何内容)

更新

public function testValidationDefault()
{
    $data = ['username' => 'adminadmin@mixtureweb.nl',
             'password' => 'testtest123',
             'sign_in_count' => 0,
             'current_sign_in_ip' => '127.0.0.1',
             'active' => true
            ];
    $user = $this->Users->newEntity($data);
    $saved = $this->Users->save($user);
    $this->assertTrue($saved);
    // $this->assertTrue($data);
}

这将给出"断言应用\模型\实体\用户对象&00000000011b3c53b0000000040aca14b 为真失败"。有谁知道我做错了什么?

看看

Table::save()返回的内容,它是CakeDatasourceEntityInterface|bool。成功时返回持久实体,失败时返回布尔false。因此,您的保存操作成功,它将返回一个实体,因此出现错误。

如果要测试验证,则应使用表类提供的验证器对象(Table::validationDefault()通过Table::validator()),或者使用Table::patchEntity()Table::newEntity()并测试Entity:errors()的值。

修补/创建实体是在模型层中进行验证的地方,保存过程将仅应用应用程序规则。

public function testValidationDefault()
{
    $data = [
        'username' => 'adminadmin@mixtureweb.nl',
        'password' => 'testtest123',
        'sign_in_count' => 0,
        'current_sign_in_ip' => '127.0.0.1',
        'active' => true
    ];
    $user = $this->Users->newEntity($data);
    $this->assertEmpty($user->errors()); // empty = no validation errors
}

参见

  • 验证>数据>说明书

  • 验证>验证实体>

  • 说明书
  • Cookbook> Database Access & ORM> Validating Data> Validation vs. Application Rules

最新更新