Pergunta

Eu estou usando equipamentos dinâmicos e sempre que eu corro meus testes eu estou recebendo um erro que pensa meu associação é uma coluna, quando deveria ser owner_id:

ActiveRecord::StatementInvalid: Mysql::Error: Unknown column 'owner' in 'field list': INSERT INTO `companies` (`custom_host`, `name`, `created_at`, `updated_at`, `api_key`, `id`, `subdomain`, `owner`) VALUES ('testerapp.com', 'Some Company', '2009-11-29 21:39:29', '2009-11-29 21:39:29', 'ae2b1fca515949e5d54fb22b8ed95575', 467557389, 'some_company', 'garrett')

No meu arquivo companies.yml eu tenho este:

some_company:
  name: Some Company
  subdomain: some_company
  custom_host: testerapp.com
  api_key: <%= "testing".to_md5 %>
  owner: garrett

E users.yml:

garrett:
  company: some_company
  login: garrett
  email: email@me.com
  ...
  locale: en
  role_name: owner

Aqui estão os meus modelos, bem como:

class Company < ActiveRecord::Base
  has_one :owner, :class_name => "User"
  has_many :users
  validates_associated :owner
end

class User < ActiveRecord::Base
  belongs_to :company
end

Poderia meu problema ser porque eu estou associando User duas vezes dentro Company? Isto está fazendo testes realmente difícil agora, e eu estava esperando que alguém poderia brilhar alguma luz sobre por que ele não está lendo meus associações corretamente.

Obrigado!

Foi útil?

Solução

Seu has_one: proprietário deve ser belongs_to: proprietário

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top