rubberband 0.1.0 → 0.1.1

Sign up to get free protection for your applications and to get access to all the features.
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- rubberband (0.0.12)
4
+ rubberband (0.1.1)
5
5
  patron
6
6
  yajl-ruby
7
7
 
@@ -69,6 +69,15 @@ module ElasticSearch
69
69
  execute(:update_mapping, indices, type, mapping, options)
70
70
  end
71
71
 
72
+ def update_settings(settings, options={})
73
+ index, type, options = extract_scope(options)
74
+ execute(:update_settings, index, settings, options)
75
+ end
76
+
77
+ def get_settings(index, options={})
78
+ execute(:get_settings, index, options)
79
+ end
80
+
72
81
  # list of indices, or :all
73
82
  # options: refresh
74
83
  # default: default_index if defined, otherwise :all
@@ -114,13 +114,19 @@ module ElasticSearch
114
114
  # Starts a bulk operation batch and yields self. Index and delete requests will be
115
115
  # queued until the block closes, then sent as a single _bulk call.
116
116
  def bulk(options={})
117
- @batch = []
118
- yield(self)
119
- response = execute(:bulk, @batch, options)
120
- ensure
121
- @batch = nil
117
+ # allow nested bulk calls
118
+ if @batch
119
+ yield(self)
120
+ else
121
+ begin
122
+ @batch = []
123
+ yield(self)
124
+ response = execute(:bulk, @batch, options)
125
+ ensure
126
+ @batch = nil
127
+ end
128
+ end
122
129
  end
123
-
124
130
  end
125
131
  end
126
132
  end
@@ -114,6 +114,14 @@ module ElasticSearch
114
114
  standard_request(:get, {:index => index_list, :op => "_mapping"})
115
115
  end
116
116
 
117
+ def update_settings(index, settings, options)
118
+ standard_request(:put, {:index => index, :op => "_settings"}, options, encoder.encode(settings))
119
+ end
120
+
121
+ def get_settings(index, options)
122
+ standard_request(:get, {:index => index, :op => "_settings"}, options)
123
+ end
124
+
117
125
  def flush(index_list, options={})
118
126
  standard_request(:post, {:index => index_list, :op => "_flush"}, options, "")
119
127
  end
@@ -1,3 +1,3 @@
1
1
  module ElasticSearch
2
- VERSION = "0.1.0"
2
+ VERSION = "0.1.1"
3
3
  end
data/spec/admin_spec.rb CHANGED
@@ -14,8 +14,12 @@ describe "basic ops" do
14
14
  it "should get and update mappings" do
15
15
  @client.index({:foo => "bar"}, :id => "1", :refresh => true)
16
16
 
17
- @client.index_mapping(@first_index).should == {@first_index => {"tweet" => { "properties" => { "foo" => {"type" => "string" }}}}}
18
17
  @client.update_mapping({"tweet" => {:properties => {:bar => {:type => "string"}}}})
19
18
  @client.index_mapping(@first_index).should == {@first_index => {"tweet" => { "properties" => { "foo" => {"type" => "string" }, "bar" => { "type" => "string"}}}}}
20
19
  end
20
+
21
+ it "should get and update settings" do
22
+ @client.update_settings("index" => {"refresh_interval" => 30})
23
+ @client.get_settings(@first_index)[@first_index]["settings"].should include("index.refresh_interval" => "30")
24
+ end
21
25
  end
data/spec/bulk_spec.rb CHANGED
@@ -28,6 +28,23 @@ describe "bulk ops" do
28
28
  @client.get("4").socks.should == "argyle"
29
29
  end
30
30
 
31
+ it "should allow nested bulk calls" do
32
+ @client.bulk do |c|
33
+ c.index({:foo => 'bar'}, :id => '11')
34
+ c.index({:foo => 'baz'}, :id => '12')
35
+ @client.bulk do
36
+ @client.index({:socks => 'stripey'}, :id => '13')
37
+ @client.index({:socks => 'argyle'}, :id => '14')
38
+ end
39
+ end
40
+ @client.refresh
41
+
42
+ @client.get("11").foo.should == "bar"
43
+ @client.get("12").foo.should == "baz"
44
+ @client.get("13").socks.should == "stripey"
45
+ @client.get("14").socks.should == "argyle"
46
+ end
47
+
31
48
  it "should take options" do
32
49
  @client.bulk do |c|
33
50
  c.index({:foo => 'bar'}, :id => '1', :_routing => '1', :_parent => '1')
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: rubberband
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.0
4
+ version: 0.1.1
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,11 +9,11 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2011-06-14 00:00:00.000000000Z
12
+ date: 2011-06-20 00:00:00.000000000Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: patron
16
- requirement: &14303940 !ruby/object:Gem::Requirement
16
+ requirement: &10698800 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ! '>='
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: '0'
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *14303940
24
+ version_requirements: *10698800
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: yajl-ruby
27
- requirement: &14303100 !ruby/object:Gem::Requirement
27
+ requirement: &10697360 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ! '>='
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: '0'
33
33
  type: :runtime
34
34
  prerelease: false
35
- version_requirements: *14303100
35
+ version_requirements: *10697360
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: rspec
38
- requirement: &14302340 !ruby/object:Gem::Requirement
38
+ requirement: &10696040 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ~>
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: '2.0'
44
44
  type: :development
45
45
  prerelease: false
46
- version_requirements: *14302340
46
+ version_requirements: *10696040
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: yard
49
- requirement: &14301800 !ruby/object:Gem::Requirement
49
+ requirement: &10695120 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ~>
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: 0.6.0
55
55
  type: :development
56
56
  prerelease: false
57
- version_requirements: *14301800
57
+ version_requirements: *10695120
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: bundler
60
- requirement: &14301220 !ruby/object:Gem::Requirement
60
+ requirement: &10693520 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ~>
@@ -65,10 +65,10 @@ dependencies:
65
65
  version: 1.0.0
66
66
  type: :development
67
67
  prerelease: false
68
- version_requirements: *14301220
68
+ version_requirements: *10693520
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: simplecov
71
- requirement: &14298880 !ruby/object:Gem::Requirement
71
+ requirement: &10691980 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ! '>='
@@ -76,10 +76,10 @@ dependencies:
76
76
  version: 0.3.8
77
77
  type: :development
78
78
  prerelease: false
79
- version_requirements: *14298880
79
+ version_requirements: *10691980
80
80
  - !ruby/object:Gem::Dependency
81
81
  name: mocha
82
- requirement: &14298320 !ruby/object:Gem::Requirement
82
+ requirement: &10688320 !ruby/object:Gem::Requirement
83
83
  none: false
84
84
  requirements:
85
85
  - - ~>
@@ -87,7 +87,7 @@ dependencies:
87
87
  version: 0.9.0
88
88
  type: :development
89
89
  prerelease: false
90
- version_requirements: *14298320
90
+ version_requirements: *10688320
91
91
  description: An ElasticSearch client with ThriftClient-like failover handling.
92
92
  email:
93
93
  - grantr@gmail.com