1

これはトランザクション フィクスチャが原因であるという投稿を読みましたが、それらを使用していないようです。各テストの実行前に、ファンキーな停止、再起動、および再インデックス付けを行うことを提案する他の投稿を読みました。それは役に立たないようです。

ThinkingSphinxアプリでは問題なく動作しますが、テストでは非常に奇妙な動作をします。Organization私の仕様でいくつかのモデルを作成した後、スフィンクス検索を実行します。私が期待している 2 つのレコードがありますが、多くのゼロもあります。これは面倒ですが、a を追加する:retry_stale => trueとそれらは消えてしまうので、この最初のクエリに満足しています。

(rdb:1) p Organization.search '', :retry_stale => true
[#<Organization id: 1, ein: nil, name: "Allina", created_at: "2012-09-11 15:03:04", updated_at: "2012-09-11 15:03:04", parent_id: nil, main_phone: "7867685187x894", fax: nil, email: nil, url: nil, crm_id: 1, target_market: false, notes: nil, form990_notes: nil, mec_revenue: 750000.0, legacy_id: nil, teaching_program_type_id: nil, sponsorship_type_id: nil, is_member_council_teaching_hospitals: nil, has_teaching_program: nil, is_major_academic_medical_center: nil, does_participate_in_survey: nil, status: "modified", net_revenue: nil, gross_revenue: nil, source_name: nil, source_id: nil, import_concat_key: nil, bigtime_id: nil, is_non_hc: nil, is_client: nil, contact_record_id: nil, form990_legacy_id: nil, number_of_beds: nil, tax_exempt_status: nil, delta: true>, #<Organization id: 2, ein: nil, name: "HealthPartners", created_at: "2012-09-11 15:03:04", updated_at: "2012-09-11 15:03:04", parent_id: nil, main_phone: "3407862693x0935", fax: nil, email: nil, url: nil, crm_id: 1, target_market: false, notes: nil, form990_notes: nil, mec_revenue: nil, legacy_id: nil, teaching_program_type_id: nil, sponsorship_type_id: nil, is_member_council_teaching_hospitals: nil, has_teaching_program: nil, is_major_academic_medical_center: nil, does_participate_in_survey: nil, status: "modified", net_revenue: nil, gross_revenue: nil, source_name: nil, source_id: nil, import_concat_key: nil, bigtime_id: nil, is_non_hc: nil, is_client: nil, contact_record_id: nil, form990_legacy_id: nil, number_of_beds: nil, tax_exempt_status: nil, delta: true>]

しかし、私のモデルで最も確実に索引付けされている名前で検索しようとすると、記録が得られません。

(rdb:1) p Organization.search 'Allina', :retry_stale => true
[]

オプションを変更しようとしてもうまくいかなかったので、スター モードで 1 文字を検索してみようと思いました。結果は不安です。

(rdb:1) p Organization.search 'C', :star => true, :retry_stale => true
[#<Organization id: 1, ein: nil, name: "Allina", created_at: "2012-09-11 15:03:04", updated_at: "2012-09-11 15:03:04", parent_id: nil, main_phone: "7867685187x894", fax: nil, email: nil, url: nil, crm_id: 1, target_market: false, notes: nil, form990_notes: nil, mec_revenue: 750000.0, legacy_id: nil, teaching_program_type_id: nil, sponsorship_type_id: nil, is_member_council_teaching_hospitals: nil, has_teaching_program: nil, is_major_academic_medical_center: nil, does_participate_in_survey: nil, status: "modified", net_revenue: nil, gross_revenue: nil, source_name: nil, source_id: nil, import_concat_key: nil, bigtime_id: nil, is_non_hc: nil, is_client: nil, contact_record_id: nil, form990_legacy_id: nil, number_of_beds: nil, tax_exempt_status: nil, delta: true>]

nameフィールドに文字「C」がないことは明らかです。私のモデルstatusは、 に設定されたフィールドにもインデックスを付け、関連付けのフィールドにmodifiedインデックスを付けます。その値は「CA」なので、そのインデックスでそのレコードを見つけているのではないかと思いました。そこで、「CA」を検索して、何が起こったのかを推測してみようと思いました。stateaddress ThinkingSphinx

(rdb:1) p Organization.search 'CA', :star => true, :retry_stale => true
[]

何もない!この不安定な動作は何ですか?わかりました、皆さんはおそらくいくつかの構成と仕様ヘルパー、およびいくつかのインデックス定義を見たいと思うでしょう:

config/sphinx.yml

development:
  enable_star: 1
  min_infix_len: 1

test:
  enable_star: 1
  min_infix_len: 1

spec/spec_helper.rb

Spork.prefork do
  require 'headless'

  headless = Headless.new(:display => 99)
  headless.start
  at_exit do
    headless.destroy
  end

  ENV["RAILS_ENV"] ||= 'test'
  require File.expand_path("../../config/environment", __FILE__)
  require 'rspec/rails'
  require 'capybara/rspec'
  require 'database_cleaner'

  #require 'rspec/autorun'
  Dir[Rails.root.join("spec/support/**/*.rb")].each {|f| require f}
  RSpec.configure do |config|
    config.use_transactional_fixtures = false
    config.treat_symbols_as_metadata_keys_with_true_values = true
    config.infer_base_class_for_anonymous_controllers = false

    config.include Devise::TestHelpers, :type => :controller
    config.extend ControllerMacros, :type => :controller
    config.include Warden::Test::Helpers, :type => :request
    config.include FactoryGirl::Syntax::Methods

    config.before(:suite) do
      DatabaseCleaner.strategy = :truncation, {
        :except => %w(sponsorship_types teaching_program_types title_groups positions tax_exempt_organization_types)}
    end

    config.before(:each) do
      DatabaseCleaner.start
    end

    config.after(:each) do
      DatabaseCleaner.clean
    end
  end
end

Spork.each_run do
end

アプリ/モデル/組織.rb

  define_index do
    indexes :name, :sortable => true
    indexes address(:state), :as => :state
    indexes status

    set_property :delta => true
  end
4

1 に答える 1

5

Test Unit で Thinking Spec テストを作成しました。それはかなりうまくいきました。spec/spec_helper.rb に以下を含めます

require 'thinking_sphinx/test'
ThinkingSphinx::Test.init

また、各テストでは、セットアップに ThinkingSphinx::Test.start を、ティアダウンに ThinkingSphinx::Test.stop を含めます。

于 2012-09-12T06:23:43.640 に答える