我gobalize
在 Rails 4.1.12 中使用 gem 4.0.3。
我有一个Post
模型,我已经运行了Post.create_translation_table!
提供的迁移globalize
来设置一个post_translations
表。
现在我想从我的夹具文件中自动加载翻译。夹具支持关联的标签引用,所以我有这个:
# spec/fixtures/posts.yml
my_first_post:
author: dave
# spec/fixtures/post_translations.yml
my_first_post_translation:
locale: en
title: My first post
content: What a time to be alive!
post: my_first_post
# spec/models/post_spec
require 'rails_helper'
RSpec.describe Post, type: :model do
fixtures('post/translations', :posts, :authors)
subject(:post) { posts(:my_first_post) }
it "has an author" do
expect(post.author).to eq(authors(:dave))
end
it "has a title" do
binding.pry
expect(post.title).to be_present
end
end
但是运行 RSpec 会引发以下错误:
Failure/Error: Unable to find matching line from backtrace
ActiveRecord::StatementInvalid:
SQLite3::SQLException: table post_translations has no column named post: INSERT INTO "post_translations" ("locale", "title", "content", "post", "created_at", "updated_at", "id") VALUES ('en', 'My first post', 'This is some compelling english content', 'my_first_post', '2015-08-21 10:23:27', '2015-08-21 10:23:27', 626768522)
如果我做相反的事情(即post_translation: my_first_translation
in posts.yml
) ,则会发生类似的错误
怎么找回魔法?