热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

持续集成,使用PropelORM将实际测试数据输入数据库的最佳实践

如何解决《持续集成,使用PropelORM将实际测试数据输入数据库的最佳实践》经验,为你挑选了1个好方法。

我使用Propel ORM复制表模式,以便进行持续集成,但Propel只让我得到一个完全充实的模式,它不会让我获得测试数据(或者根本不需要基本的必要数据).

如何从具有版本控制的propel-genPropel ORM生态系统的实时/测试数据库中获取数据?



1> halfer..:

他们说任何事物中的"最佳实践"都不存在 - 它是如此主观,以至于人们应该选择几种形式的"良好实践".我认为下面的标签符合该标签 - 最终它对我有用.我一直在使用PHPUnit大约一年,也许我的项目从头开始使用六个月.

这是我在PHPUnit引导阶段(指定phpunit.xml)中所做的事情的概要:

删除并创建myproject_test数据库

insert-sql在生成的SQL的迁移前副本上调用Propel命令

调用migratePropel命令

扫描我的测试文件夹以获取构建类以设置测试,并依次运行每个测试

手动插入SQL然后运行迁移的好处是迁移得到了彻底的测试.这是特别方便的,因为在开发中我有时会做一个down,修改一个迁移类,然后up重新运行它:因此可以放心地知道它将按顺序运行.目前我计划永久保留我的所有移民历史; 虽然它会给测试和新版本增加非常小的延迟,但升级部署不会受到影响.

由于我的构建依赖于具有旧的SQL文件,因此我避免使用sqlgeneration命令; 如果意外发出,修改后的SQL文件可以在版本控制中轻松恢复.

目前,我只是使用myproject_teston 的数据库名称localhost,因此无论运行哪个测试,其他数据库都不会受到影响.在构建服务器上,您可能需要使用不同的凭据进行连接:请考虑在switch()语句中检测计算机名称,并相应地选择连接详细信息.

为了给您测试数据,我通常倾向于建议您不要使用实时系统中的数据导出.通常情况下,它通常太多,而且您通常也希望每次测试创建数据片段,以便测试完全隔离.我认为这是一个好主意有两个原因:

您可以并行化独立的测试.因此,当您的浏览器测试套件运行需要五个小时(!)时,您可以设置更多构建服务器以更快地获得绿色构建.

您可能希望本地运行测试套件,或者单独进行测试,或者匹配某个字符串的一组测试,如果一个测试依赖于另一个测试,这可能不起作用.

这是我的构建器类的用武之地.我在我的中使用bootstrap.php它并在包含测试类的每个文件夹上调用它:

function runBuilders($buildFolder, $namespace)
{
    // I use ! to mark common builders that need to be run first.
    // Since this confuses autoloader, I load that manually.
    $commOnBuilder= $buildFolder . '/!CommonBuild.php';
    if (file_exists($commonBuilder))
    {
        require_once $commonBuilder;
    }

    foreach(glob($buildFolder . '/*Build.php') as $class)
    {
        $matches = array();
        $found = preg_match('#/([!a-zA-Z]+)\.php#', $class, $matches);
        if ($found)
        {
            echo '.';

            // Don't use ! characters when creating the class
            $className = str_replace('!', '', $matches[1]);
            call_user_func($namespace . "\\{$className}::build");
        }
    }
}

!CommonBuild.php我添加不会被测试修改的只读数据,因此只有一个副本是安全的.

每个PHPUnit测试类都有一个构建类:对于*Test.php我拥有的每个文件,我都会有相应的*Build.php.在每个构建器中,build调用静态方法,并在其中为每个需要构建的测试手动运行方法.这是一个简单的:

public static function build()
{
    self::buildWriteVarToFieldSuccessfully();
    self::buildWriteVarToFieldUsingFailedMatch();
    self::buildWriteVarToFieldUsingFoundMatch();
    self::buildFailIfVariableIsAnArray();
}

在未来的某个时候,我可能会使用Reflection来自动运行这些,就像PHPUnit用于测试一样,但它现在还可以.

现在,在我的引导脚本中,我使用测试连接完全初始化Propel,因此可以使用普通的Propel语句.因此,我将创建我需要的数据,如下所示:

protected static function buildWriteVarToFieldUsingFoundMatch()
{
    // Save an item in the holding table
    $employer = self::createEmployer();
    $job = new \Job\Model\JobHolding();
    $job->setReference('12345');
    $job->setLocationAlias('Rhubarb patch');
    $job->setEmployerId($employer->getPrimaryKey());
    $job->save();

    $process = self::createProcessingUsingRowMatching($employer);
    $process->createSource('VarToFieldTest_buildWriteVarToFieldUsingFoundMatch');
}

我有一个命名约定,testWriteVarToFieldUsingFoundMatch测试类中的测试获取buildWriteVarToFieldUsingFoundMatch在相应的构建类中调用的构建器.它在代码中没有强制执行,但是这个命名有助于轻松找到另一个(我经常使用IDE的分屏功能同时编辑两者).

因此,在上面的示例中,我只需要一个雇主记录,一个作业记录,一个流程记录和一个源记录来运行此特定测试(而不是整个实时导出).源记录被赋予一个与测试名称相关的唯一名称,因此它只会在此测试中使用(我发现我必须注意这里的复制和粘贴错误 - 它很容易使用测试中的错误数据!).

创建这种类型的测试数据非常简单,无论您拥有何种类型的数据库:通常可以创建包含唯一标识符的user.name字段,address.line1字段等,以便在测试中修改此数据时,您知道只有该测试是要使用它,因此它与其他测试隔离.

出于简单的原因,我选择在引导程序中运行所有构建器,而不管正在运行哪些测试.因为这只需要15秒,在我的情况下,可能不值得做一些更复杂的事情.但是,如果您愿意,可以使用setUp每个PHPUnit测试中的方法做一些聪明的事情,检测当前测试(如果可能),然后运行相应的构建类.


推荐阅读
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • Day2列表、字典、集合操作详解
    本文详细介绍了列表、字典、集合的操作方法,包括定义列表、访问列表元素、字符串操作、字典操作、集合操作、文件操作、字符编码与转码等内容。内容详实,适合初学者参考。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 本文介绍了使用PHP实现断点续传乱序合并文件的方法和源码。由于网络原因,文件需要分割成多个部分发送,因此无法按顺序接收。文章中提供了merge2.php的源码,通过使用shuffle函数打乱文件读取顺序,实现了乱序合并文件的功能。同时,还介绍了filesize、glob、unlink、fopen等相关函数的使用。阅读本文可以了解如何使用PHP实现断点续传乱序合并文件的具体步骤。 ... [详细]
  • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • Java学习笔记之使用反射+泛型构建通用DAO
    本文介绍了使用反射和泛型构建通用DAO的方法,通过减少代码冗余度来提高开发效率。通过示例说明了如何使用反射和泛型来实现对不同表的相同操作,从而避免重复编写相似的代码。该方法可以在Java学习中起到较大的帮助作用。 ... [详细]
  • 本文主要复习了数据库的一些知识点,包括环境变量设置、表之间的引用关系等。同时介绍了一些常用的数据库命令及其使用方法,如创建数据库、查看已存在的数据库、切换数据库、创建表等操作。通过本文的学习,可以加深对数据库的理解和应用能力。 ... [详细]
  • 在Oracle11g以前版本中的的DataGuard物理备用数据库,可以以只读的方式打开数据库,但此时MediaRecovery利用日志进行数据同步的过 ... [详细]
  • MySQL语句大全:创建、授权、查询、修改等【MySQL】的使用方法详解
    本文详细介绍了MySQL语句的使用方法,包括创建用户、授权、查询、修改等操作。通过连接MySQL数据库,可以使用命令创建用户,并指定该用户在哪个主机上可以登录。同时,还可以设置用户的登录密码。通过本文,您可以全面了解MySQL语句的使用方法。 ... [详细]
author-avatar
顽童0006_648
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有