5

使用催化剂时,是否可以像在 Rails 中那样指定开发、测试和生产数据库?我浏览了文档,但没有找到答案。

4

1 回答 1

4

参考cpan Catalyst Testing Tutorial

您可能希望为您的实时应用程序维护一个“生产数据库”和为您的测试用例维护一个“测试数据库”。

模型类中的数据库配置切换

一种解决方案是允许使用环境变量覆盖数据库规范。例如,在编辑器中打开 lib/MyApp/Model/MyAppDB.pm 并将 __PACKAGE__->config(...声明更改为:

my $dsn = $ENV{MYAPP_DSN} ||= 'dbi:SQLite:myapp.db';
__PACKAGE__->config(
    schema_class => 'MyAppDB',
    connect_info => [
        $dsn,
        '',
        '',
        { AutoCommit => 1 },

    ],
);

然后,当您运行测试用例时,您可以使用以下命令:

$ cp myapp.db myappTEST.db
$ CATALYST_DEBUG=0 MYAPP_DSN="dbi:SQLite:myappTEST.db" 证明 --lib lib -vt/live_app01.t

这将仅在测试用例运行时修改 DSN。如果您在未定义 MYAPP_DSN 环境变量的情况下启动普通应用程序,它将默认为与以前相同的 dbi:SQLite:myapp.db。

使用多个配置文件进行数据库配置切换

通过利用Catalyst::Plugin::ConfigLoader的基于环境变量加载多个配置文件的功能,您可以覆盖默认(生产)数据库连接设置。

在测试脚本中将 $ENV{ MYAPP_CONFIG_LOCAL_SUFFIX } 设置为“testing”会导致在 myapp.conf 之后加载一个名为 myapp_testing.conf 的附加配置文件,该文件将覆盖 myapp.conf 中的任何参数。

您应该在测试脚本的 BEGIN 块中设置环境变量,以确保在启动 Catalyst 应用程序之前设置它。

以下是名为 MyDB 的 DBIx::Class 模型和名为 Foo 的控制器的配置和测试脚本的示例:

myapp_testing.conf:

<Model::MyDB>
    <connect_info>
        dsn dbi:SQLite:myapp.db
    </connect_info>
</Model::MyDB>

使用单独的数据库时也要检查这个

于 2013-02-07T14:27:42.447 回答