thinking-sphinx 4.2.0 → 4.3.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.travis.yml +6 -12
- data/CHANGELOG.markdown +16 -0
- data/README.textile +2 -2
- data/bin/loadsphinx +45 -53
- data/lib/thinking_sphinx/commands/base.rb +4 -0
- data/lib/thinking_sphinx/commands/prepare.rb +2 -0
- data/lib/thinking_sphinx/commands/running.rb +2 -0
- data/lib/thinking_sphinx/commands/start_attached.rb +1 -1
- data/lib/thinking_sphinx/commands/start_detached.rb +1 -1
- data/lib/thinking_sphinx/configuration.rb +5 -2
- data/lib/thinking_sphinx/configuration/distributed_indices.rb +1 -1
- data/lib/thinking_sphinx/core/index.rb +4 -1
- data/lib/thinking_sphinx/distributed/index.rb +13 -3
- data/spec/acceptance/facets_spec.rb +14 -0
- data/spec/thinking_sphinx/commands/prepare_spec.rb +9 -1
- data/spec/thinking_sphinx/commands/running_spec.rb +30 -0
- data/spec/thinking_sphinx/commands/start_detached_spec.rb +11 -1
- data/spec/thinking_sphinx/configuration_spec.rb +15 -2
- data/thinking-sphinx.gemspec +1 -1
- metadata +6 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 30fe9d6940dc5f385310346374829bc1ff941332583060ad549ea8675a6a34ce
|
4
|
+
data.tar.gz: 4b5a25fe1120cba82bf9bd6b9f80be7e1d5175dce887d8acaffc3ba1da78e458
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f8f25c99b61c6bf80f9a81eb71ab1c1a6af005009099cd18c7ef1a13e694f4e65b7ddc3d654167033ecf0fac072c91d88864d6ab5cf44c5f00fea69447195ce2
|
7
|
+
data.tar.gz: b78abfa34ebcfb24ed65e99b07dfb04dc545cc2be74c994a9b786a507b8b69bfa46afce05c74830dfde5bebc6b823e0d44b3073637967090b35ffe85c9629b41
|
data/.travis.yml
CHANGED
@@ -1,15 +1,9 @@
|
|
1
1
|
language: ruby
|
2
2
|
rvm:
|
3
3
|
- 2.3.8
|
4
|
-
- 2.4.
|
5
|
-
- 2.5.
|
6
|
-
- 2.6.
|
7
|
-
addons:
|
8
|
-
apt:
|
9
|
-
packages:
|
10
|
-
- cmake
|
11
|
-
- bison
|
12
|
-
- flex
|
4
|
+
- 2.4.6
|
5
|
+
- 2.5.5
|
6
|
+
- 2.6.2
|
13
7
|
before_install:
|
14
8
|
- pip install --upgrade --user awscli
|
15
9
|
- gem update --system
|
@@ -23,7 +17,6 @@ before_script:
|
|
23
17
|
script: bundle exec appraisal rspec
|
24
18
|
env:
|
25
19
|
global:
|
26
|
-
- SPHINX_BIN=ext/sphinx/bin/
|
27
20
|
- secure: cUPinkilBafqDSPsTkl/PXYc2aXNKUQKXGK8poBBMqKN9/wjfJx1DWgtowDKalekdZELxDhc85Ye3bL1xlW4nLjOu+U6Tkt8eNw2Nhs1flodHzA/RyENdBLr/tBHt43EjkrDehZx5sBHmWQY4miHs8AJz0oKO9Ae2inTOHx9Iuc=
|
28
21
|
matrix:
|
29
22
|
- DATABASE=mysql2 SPHINX_VERSION=2.1.9 SPHINX_ENGINE=sphinx
|
@@ -37,11 +30,12 @@ env:
|
|
37
30
|
- DATABASE=postgresql SPHINX_VERSION=2.6.4 SPHINX_ENGINE=manticore
|
38
31
|
- DATABASE=mysql2 SPHINX_VERSION=2.7.5 SPHINX_ENGINE=manticore
|
39
32
|
- DATABASE=postgresql SPHINX_VERSION=2.7.5 SPHINX_ENGINE=manticore
|
40
|
-
- DATABASE=mysql2 SPHINX_VERSION=2.8.
|
41
|
-
- DATABASE=postgresql SPHINX_VERSION=2.8.
|
33
|
+
- DATABASE=mysql2 SPHINX_VERSION=2.8.2 SPHINX_ENGINE=manticore
|
34
|
+
- DATABASE=postgresql SPHINX_VERSION=2.8.2 SPHINX_ENGINE=manticore
|
42
35
|
# - DATABASE=postgresql SPHINX_VERSION=3.1.1 SPHINX_ENGINE=sphinx
|
43
36
|
sudo: false
|
44
37
|
addons:
|
45
38
|
postgresql: '9.4'
|
46
39
|
services:
|
40
|
+
- mysql
|
47
41
|
- postgresql
|
data/CHANGELOG.markdown
CHANGED
@@ -2,8 +2,24 @@
|
|
2
2
|
|
3
3
|
All notable changes to this project (at least, from v3.0.0 onwards) are documented in this file.
|
4
4
|
|
5
|
+
## 4.3.0 - 2019-05-18
|
6
|
+
|
7
|
+
[Release Notes](https://github.com/pat/thinking-sphinx/releases/tag/v4.3.0)
|
8
|
+
|
9
|
+
### Added
|
10
|
+
|
11
|
+
* Allow overriding of Sphinx's running state, which is useful when Sphinx commands are interacting with a remote Sphinx daemon. As per discussions in [#1131](https://github.com/pat/thinking-sphinx/pull/1124).
|
12
|
+
* Allow skipping of directory creation, as per discussions in [#1131](https://github.com/pat/thinking-sphinx/pull/1131).
|
13
|
+
|
14
|
+
### Fixed
|
15
|
+
|
16
|
+
* Use ActiveSupport's lock monitor where possible (Rails 5.1.5 onwards) to avoid database deadlocks. Essential investigation by [Jonathan del Strother](https://github.com/jdelstrother) ([#1132](https://github.com/pat/thinking-sphinx/pull/1132)).
|
17
|
+
* Allow facet searching on distributed indices ([#1135](https://github.com/pat/thinking-sphinx/pull/1132)).
|
18
|
+
|
5
19
|
## 4.2.0 - 2019-03-09
|
6
20
|
|
21
|
+
[Release Notes](https://github.com/pat/thinking-sphinx/releases/tag/v4.2.0)
|
22
|
+
|
7
23
|
### Added
|
8
24
|
|
9
25
|
* Allow changing the default encoding for MySQL database connections from utf8 to something else via the `mysql_encoding` setting in `config/thinking_sphinx.yml`. In the next significant release, the default will change to utf8mb4 (which is supported in MySQL 5.5.3 and newer).
|
data/README.textile
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
h1. Thinking Sphinx
|
2
2
|
|
3
|
-
Thinking Sphinx is a library for connecting ActiveRecord to the Sphinx full-text search tool, and integrates closely with Rails (but also works with other Ruby web frameworks). The current release is v4.
|
3
|
+
Thinking Sphinx is a library for connecting ActiveRecord to the Sphinx full-text search tool, and integrates closely with Rails (but also works with other Ruby web frameworks). The current release is v4.3.0.
|
4
4
|
|
5
5
|
h2. Upgrading
|
6
6
|
|
@@ -14,7 +14,7 @@ It's a gem, so install it like you would any other gem. You will also need to sp
|
|
14
14
|
|
15
15
|
<pre><code>gem 'mysql2', '~> 0.3', :platform => :ruby
|
16
16
|
gem 'jdbc-mysql', '~> 5.1.35', :platform => :jruby
|
17
|
-
gem 'thinking-sphinx', '~> 4.
|
17
|
+
gem 'thinking-sphinx', '~> 4.3'</code></pre>
|
18
18
|
|
19
19
|
The MySQL gems mentioned are required for connecting to Sphinx, so please include it even when you're using PostgreSQL for your database. If you're using JRuby with a version of Sphinx prior to 2.2.11, there is "currently an issue with Sphinx and jdbc-mysql 5.1.36 or newer":http://sphinxsearch.com/forum/view.html?id=13939, so you'll need to stick to nothing more recent than 5.1.35, or upgrade Sphinx.
|
20
20
|
|
data/bin/loadsphinx
CHANGED
@@ -2,65 +2,57 @@
|
|
2
2
|
|
3
3
|
version=$1
|
4
4
|
engine=$2
|
5
|
-
name="$engine-$version"
|
6
|
-
bucket="thinking-sphinx"
|
7
|
-
directory="ext/sphinx"
|
8
|
-
prefix="`pwd`/$directory"
|
9
|
-
file="ext/$name.tar.gz"
|
10
5
|
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
6
|
+
load_sphinx () {
|
7
|
+
case $version in
|
8
|
+
2.1.9)
|
9
|
+
url="http://sphinxsearch.com/files/sphinxsearch_2.1.9-release-0ubuntu11~trusty_amd64.deb"
|
10
|
+
format="deb";;
|
11
|
+
2.2.11)
|
12
|
+
url="http://sphinxsearch.com/files/sphinxsearch_2.2.11-release-1~trusty_amd64.deb"
|
13
|
+
format="deb";;
|
14
|
+
3.0.3)
|
15
|
+
url="http://sphinxsearch.com/files/sphinx-3.0.3-facc3fb-linux-amd64.tar.gz"
|
16
|
+
format="gz";;
|
17
|
+
3.1.1)
|
18
|
+
url="http://sphinxsearch.com/files/sphinx-3.1.1-612d99f-linux-amd64.tar.gz"
|
19
|
+
format="gz";;
|
20
|
+
*)
|
21
|
+
echo "No Sphinx version $version available"
|
22
|
+
exit 1;;
|
23
|
+
esac
|
24
|
+
|
25
|
+
if [ "$format" == "deb" ]; then
|
26
|
+
curl --location $url -o sphinx.deb
|
27
|
+
sudo apt-get install ./sphinx.deb
|
20
28
|
else
|
21
|
-
|
29
|
+
curl $url -o sphinx.tar.gz
|
30
|
+
tar -zxvf sphinx.tar.gz
|
31
|
+
sudo mv sphinx-$version/bin/* /usr/local/bin/.
|
22
32
|
fi
|
23
33
|
}
|
24
34
|
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
cmake -D WITH_MYSQL=TRUE -D WITH_PGSQL=TRUE -D DISABLE_TESTING=TRUE -D CMAKE_INSTALL_PREFIX=$prefix ..
|
43
|
-
make -j4
|
44
|
-
make install
|
45
|
-
cd ../..
|
46
|
-
rm -rf $engine
|
35
|
+
load_manticore () {
|
36
|
+
url="https://github.com/manticoresoftware/manticore/releases/download/$version/manticore_$version.deb"
|
37
|
+
|
38
|
+
case $version in
|
39
|
+
2.6.4)
|
40
|
+
url="https://github.com/manticoresoftware/manticoresearch/releases/download/2.6.4/manticore_2.6.4-180503-37308c3-release-stemmer.trusty_amd64-bin.deb";;
|
41
|
+
2.7.5)
|
42
|
+
url="https://github.com/manticoresoftware/manticoresearch/releases/download/2.7.5/manticore_2.7.5-181204-0f016406-release-stemmer.trusty_amd64-bin.deb";;
|
43
|
+
2.8.2)
|
44
|
+
url="https://github.com/manticoresoftware/manticoresearch/releases/download/2.8.2/manticore_2.8.2-190402-4e81114-release-stemmer.trusty_amd64-bin.deb";;
|
45
|
+
*)
|
46
|
+
echo "No Manticore version $version available"
|
47
|
+
exit 1;;
|
48
|
+
esac
|
49
|
+
|
50
|
+
curl --location $url -o manticore.deb
|
51
|
+
sudo apt-get install ./manticore.deb
|
47
52
|
}
|
48
53
|
|
49
|
-
|
50
|
-
|
51
|
-
curl -o $file http://$bucket.s3.amazonaws.com/bincaches/$name.tar.gz
|
52
|
-
tar -zxf $file
|
53
|
-
}
|
54
|
-
|
55
|
-
push_cache () {
|
56
|
-
tar -czf $file $directory
|
57
|
-
aws s3 cp $file s3://$bucket/bincaches/$name.tar.gz --acl public-read
|
58
|
-
}
|
59
|
-
|
60
|
-
if curl -i --head --fail http://$bucket.s3.amazonaws.com/bincaches/$name.tar.gz
|
61
|
-
then
|
62
|
-
load_cache
|
54
|
+
if [ "$engine" == "sphinx" ]; then
|
55
|
+
load_sphinx
|
63
56
|
else
|
64
|
-
|
65
|
-
push_cache
|
57
|
+
load_manticore
|
66
58
|
fi
|
@@ -2,7 +2,7 @@
|
|
2
2
|
|
3
3
|
class ThinkingSphinx::Commands::StartAttached < ThinkingSphinx::Commands::Base
|
4
4
|
def call
|
5
|
-
FileUtils.mkdir_p configuration.indices_location
|
5
|
+
FileUtils.mkdir_p configuration.indices_location unless skip_directories?
|
6
6
|
|
7
7
|
unless pid = fork
|
8
8
|
controller.start :verbose => options[:verbose], :nodetach => true
|
@@ -2,7 +2,7 @@
|
|
2
2
|
|
3
3
|
class ThinkingSphinx::Commands::StartDetached < ThinkingSphinx::Commands::Base
|
4
4
|
def call
|
5
|
-
FileUtils.mkdir_p configuration.indices_location
|
5
|
+
FileUtils.mkdir_p configuration.indices_location unless skip_directories?
|
6
6
|
|
7
7
|
result = controller.start :verbose => options[:verbose]
|
8
8
|
|
@@ -10,7 +10,8 @@ class ThinkingSphinx::Configuration < Riddle::Configuration
|
|
10
10
|
|
11
11
|
delegate :environment, :to => :framework
|
12
12
|
|
13
|
-
@@mutex =
|
13
|
+
@@mutex = defined?(ActiveSupport::Concurrency::LoadInterlockAwareMonitor) ?
|
14
|
+
ActiveSupport::Concurrency::LoadInterlockAwareMonitor.new : Mutex.new
|
14
15
|
|
15
16
|
def initialize
|
16
17
|
super
|
@@ -105,7 +106,9 @@ class ThinkingSphinx::Configuration < Riddle::Configuration
|
|
105
106
|
end
|
106
107
|
|
107
108
|
def render_to_file
|
108
|
-
|
109
|
+
unless settings['skip_directory_creation'] || searchd.binlog_path.blank?
|
110
|
+
FileUtils.mkdir_p searchd.binlog_path
|
111
|
+
end
|
109
112
|
|
110
113
|
open(configuration_file, 'w') { |file| file.write render }
|
111
114
|
end
|
@@ -21,7 +21,7 @@ class ThinkingSphinx::Configuration::DistributedIndices
|
|
21
21
|
|
22
22
|
def distributed_index(reference, indices)
|
23
23
|
index = ThinkingSphinx::Distributed::Index.new reference
|
24
|
-
index.
|
24
|
+
index.local_index_objects = indices
|
25
25
|
index
|
26
26
|
end
|
27
27
|
|
@@ -98,7 +98,10 @@ module ThinkingSphinx::Core::Index
|
|
98
98
|
end
|
99
99
|
|
100
100
|
def set_path
|
101
|
-
|
101
|
+
unless config.settings['skip_directory_creation']
|
102
|
+
FileUtils.mkdir_p path_prefix
|
103
|
+
end
|
104
|
+
|
102
105
|
@path = File.join path_prefix, name
|
103
106
|
end
|
104
107
|
end
|
@@ -3,11 +3,12 @@
|
|
3
3
|
class ThinkingSphinx::Distributed::Index <
|
4
4
|
Riddle::Configuration::DistributedIndex
|
5
5
|
|
6
|
-
attr_reader :reference, :options
|
6
|
+
attr_reader :reference, :options, :local_index_objects
|
7
7
|
|
8
8
|
def initialize(reference)
|
9
|
-
@reference
|
10
|
-
@options
|
9
|
+
@reference = reference
|
10
|
+
@options = {}
|
11
|
+
@local_index_objects = []
|
11
12
|
|
12
13
|
super reference.to_s.gsub('/', '_')
|
13
14
|
end
|
@@ -20,6 +21,15 @@ class ThinkingSphinx::Distributed::Index <
|
|
20
21
|
true
|
21
22
|
end
|
22
23
|
|
24
|
+
def facets
|
25
|
+
local_index_objects.collect(&:facets).flatten
|
26
|
+
end
|
27
|
+
|
28
|
+
def local_index_objects=(indices)
|
29
|
+
self.local_indices = indices.collect(&:name)
|
30
|
+
@local_index_objects = indices
|
31
|
+
end
|
32
|
+
|
23
33
|
def model
|
24
34
|
@model ||= reference.to_s.camelize.constantize
|
25
35
|
end
|
@@ -124,4 +124,18 @@ describe 'Faceted searching', :live => true do
|
|
124
124
|
calls += 1
|
125
125
|
end
|
126
126
|
end
|
127
|
+
|
128
|
+
it "can be called on distributed indices" do
|
129
|
+
blue = Colour.create! :name => 'blue'
|
130
|
+
green = Colour.create! :name => 'green'
|
131
|
+
|
132
|
+
Tee.create! :colour => blue
|
133
|
+
Tee.create! :colour => blue
|
134
|
+
Tee.create! :colour => green
|
135
|
+
index
|
136
|
+
|
137
|
+
expect(Tee.facets(:indices => ["tee"]).to_hash[:colour_id]).to eq({
|
138
|
+
blue.id => 2, green.id => 1
|
139
|
+
})
|
140
|
+
end
|
127
141
|
end
|
@@ -7,7 +7,7 @@ RSpec.describe ThinkingSphinx::Commands::Prepare do
|
|
7
7
|
configuration, {}, stream
|
8
8
|
) }
|
9
9
|
let(:configuration) { double 'configuration',
|
10
|
-
:indices_location => '/path/to/indices'
|
10
|
+
:indices_location => '/path/to/indices', :settings => {}
|
11
11
|
}
|
12
12
|
let(:stream) { double :puts => nil }
|
13
13
|
|
@@ -20,4 +20,12 @@ RSpec.describe ThinkingSphinx::Commands::Prepare do
|
|
20
20
|
|
21
21
|
command.call
|
22
22
|
end
|
23
|
+
|
24
|
+
it "skips directory creation if flag is set" do
|
25
|
+
configuration.settings['skip_directory_creation'] = true
|
26
|
+
|
27
|
+
expect(FileUtils).to_not receive(:mkdir_p)
|
28
|
+
|
29
|
+
command.call
|
30
|
+
end
|
23
31
|
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'spec_helper'
|
4
|
+
|
5
|
+
RSpec.describe ThinkingSphinx::Commands::Running do
|
6
|
+
let(:command) { ThinkingSphinx::Commands::Running.new(
|
7
|
+
configuration, {}, stream
|
8
|
+
) }
|
9
|
+
let(:configuration) {
|
10
|
+
double 'configuration', :controller => controller, :settings => {}
|
11
|
+
}
|
12
|
+
let(:stream) { double :puts => nil }
|
13
|
+
let(:controller) { double 'controller', :running? => false }
|
14
|
+
|
15
|
+
it 'returns true when Sphinx is running' do
|
16
|
+
allow(controller).to receive(:running?).and_return(true)
|
17
|
+
|
18
|
+
expect(command.call).to eq(true)
|
19
|
+
end
|
20
|
+
|
21
|
+
it 'returns false when Sphinx is not running' do
|
22
|
+
expect(command.call).to eq(false)
|
23
|
+
end
|
24
|
+
|
25
|
+
it 'returns true if the flag is set' do
|
26
|
+
configuration.settings['skip_running_check'] = true
|
27
|
+
|
28
|
+
expect(command.call).to eq(true)
|
29
|
+
end
|
30
|
+
end
|
@@ -6,7 +6,9 @@ RSpec.describe ThinkingSphinx::Commands::StartDetached do
|
|
6
6
|
let(:command) {
|
7
7
|
ThinkingSphinx::Commands::StartDetached.new(configuration, {}, stream)
|
8
8
|
}
|
9
|
-
let(:configuration) {
|
9
|
+
let(:configuration) {
|
10
|
+
double 'configuration', :controller => controller, :settings => {}
|
11
|
+
}
|
10
12
|
let(:controller) { double 'controller', :start => result, :pid => 101 }
|
11
13
|
let(:result) { double 'result', :command => 'start', :status => 1,
|
12
14
|
:output => '' }
|
@@ -29,6 +31,14 @@ RSpec.describe ThinkingSphinx::Commands::StartDetached do
|
|
29
31
|
command.call
|
30
32
|
end
|
31
33
|
|
34
|
+
it "skips directory creation if flag is set" do
|
35
|
+
configuration.settings['skip_directory_creation'] = true
|
36
|
+
|
37
|
+
expect(FileUtils).to_not receive(:mkdir_p)
|
38
|
+
|
39
|
+
command.call
|
40
|
+
end
|
41
|
+
|
32
42
|
it "starts the daemon" do
|
33
43
|
expect(controller).to receive(:start)
|
34
44
|
|
@@ -342,10 +342,13 @@ describe ThinkingSphinx::Configuration do
|
|
342
342
|
end
|
343
343
|
|
344
344
|
describe '#render_to_file' do
|
345
|
-
let(:file)
|
346
|
-
let(:output)
|
345
|
+
let(:file) { double('file') }
|
346
|
+
let(:output) { config.render }
|
347
|
+
let(:skip_directories) { false }
|
347
348
|
|
348
349
|
before :each do
|
350
|
+
write_configuration('skip_directory_creation' => skip_directories)
|
351
|
+
|
349
352
|
allow(config.searchd).to receive_messages :render => 'searchd { }'
|
350
353
|
end
|
351
354
|
|
@@ -376,6 +379,16 @@ describe ThinkingSphinx::Configuration do
|
|
376
379
|
|
377
380
|
config.render_to_file
|
378
381
|
end
|
382
|
+
|
383
|
+
context 'skipping directory creation' do
|
384
|
+
let(:skip_directories) { true }
|
385
|
+
|
386
|
+
it "skips creating a directory when flag is set" do
|
387
|
+
expect(FileUtils).not_to receive(:mkdir_p)
|
388
|
+
|
389
|
+
config.render_to_file
|
390
|
+
end
|
391
|
+
end
|
379
392
|
end
|
380
393
|
|
381
394
|
describe '#searchd' do
|
data/thinking-sphinx.gemspec
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: thinking-sphinx
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 4.
|
4
|
+
version: 4.3.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Pat Allan
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2019-
|
11
|
+
date: 2019-05-18 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activerecord
|
@@ -454,6 +454,7 @@ files:
|
|
454
454
|
- spec/thinking_sphinx/commands/merge_and_update_spec.rb
|
455
455
|
- spec/thinking_sphinx/commands/merge_spec.rb
|
456
456
|
- spec/thinking_sphinx/commands/prepare_spec.rb
|
457
|
+
- spec/thinking_sphinx/commands/running_spec.rb
|
457
458
|
- spec/thinking_sphinx/commands/start_detached_spec.rb
|
458
459
|
- spec/thinking_sphinx/commands/stop_spec.rb
|
459
460
|
- spec/thinking_sphinx/configuration/minimum_fields_spec.rb
|
@@ -520,7 +521,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
520
521
|
- !ruby/object:Gem::Version
|
521
522
|
version: '0'
|
522
523
|
requirements: []
|
523
|
-
|
524
|
+
rubyforge_project: thinking-sphinx
|
525
|
+
rubygems_version: 2.7.6.2
|
524
526
|
signing_key:
|
525
527
|
specification_version: 4
|
526
528
|
summary: A smart wrapper over Sphinx for ActiveRecord
|
@@ -630,6 +632,7 @@ test_files:
|
|
630
632
|
- spec/thinking_sphinx/commands/merge_and_update_spec.rb
|
631
633
|
- spec/thinking_sphinx/commands/merge_spec.rb
|
632
634
|
- spec/thinking_sphinx/commands/prepare_spec.rb
|
635
|
+
- spec/thinking_sphinx/commands/running_spec.rb
|
633
636
|
- spec/thinking_sphinx/commands/start_detached_spec.rb
|
634
637
|
- spec/thinking_sphinx/commands/stop_spec.rb
|
635
638
|
- spec/thinking_sphinx/configuration/minimum_fields_spec.rb
|