Domanda

Sto usando dispositivi dinamici e ogni volta che eseguo i miei test ricevo un errore che pensa che la mia associazione sia una colonna, quando dovrebbe essere 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')

Nel mio file companies.yml ho questo:

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

Ecco anche i miei modelli:

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

Il mio problema potrebbe essere dovuto al fatto che sto associando User due volte all'interno di Company ? Questo sta rendendo i test davvero difficili in questo momento, e speravo che qualcuno potesse far luce sul perché non sta leggendo correttamente le mie associazioni.

Grazie!

È stato utile?

Soluzione

Il tuo has_one: il proprietario dovrebbe essere appartiene_to: proprietario

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top