Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

prepare 5.8.0 release #159

Merged
merged 257 commits into from
May 27, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
257 commits
Select commit Hold shift + click to select a range
73f2d89
provide as_json method that returns a hash instead of just a string
eli-darkly Aug 20, 2018
ab896b1
state can be serialized with JSON.generate
eli-darkly Aug 21, 2018
00347c6
add $valid
eli-darkly Aug 21, 2018
bdac27e
add ability to filter for only client-side flags
eli-darkly Aug 21, 2018
748b59b
Merge pull request #76 from launchdarkly/eb/ch22308/all-flags-state
eli-darkly Aug 21, 2018
50b3aa5
Merge pull request #77 from launchdarkly/eb/ch12124/client-side-filter
eli-darkly Aug 21, 2018
cee4c18
implement evaluation with explanations
eli-darkly Aug 23, 2018
d2c2ab8
misc cleanup
eli-darkly Aug 23, 2018
64a00a1
misc cleanup, more error checking
eli-darkly Aug 23, 2018
46b642b
don't keep evaluating prerequisites if one fails
eli-darkly Aug 23, 2018
855c4e2
doc comment
eli-darkly Aug 23, 2018
a0f002f
rename variation to variation_index
eli-darkly Aug 23, 2018
4ec43db
comment
eli-darkly Aug 23, 2018
9622e01
more test coverage, convenience method
eli-darkly Aug 24, 2018
7a453b0
Merge branch 'master' of github.com:launchdarkly/ruby-client
eli-darkly Aug 27, 2018
88d217e
Merge branch 'master' of github.com:launchdarkly/ruby-client
eli-darkly Aug 27, 2018
084d9ea
fix event generation for a prerequisite that is off
eli-darkly Aug 29, 2018
02b5712
fix private
eli-darkly Aug 29, 2018
53e8408
Merge pull request #78 from launchdarkly/eb/ch19976/explanations
eli-darkly Aug 29, 2018
c78db15
Merge pull request #79 from launchdarkly/eb/ch22995/prereq-off
eli-darkly Aug 29, 2018
960bb89
Merge branch 'explanation'
eli-darkly Aug 30, 2018
39d6ad1
Merge branch 'master' of github.com:launchdarkly/ruby-client
eli-darkly Aug 30, 2018
8867638
add option to reduce front-end metadata for untracked flags
eli-darkly Oct 5, 2018
7ac39ba
Merge pull request #80 from launchdarkly/eb/ch24449/less-metadata
eli-darkly Oct 5, 2018
9ea43e0
fix logic for whether a flag is tracked in all_flags_state
eli-darkly Oct 8, 2018
cbbc2ea
Merge pull request #81 from launchdarkly/eb/ch24449/less-metadata-2
eli-darkly Oct 15, 2018
c79745a
merge from public after release
LaunchDarklyCI Oct 24, 2018
cce8e84
implement file data source
eli-darkly Oct 31, 2018
22ebded
add poll interval param, tolerate single file path string, add doc co…
eli-darkly Oct 31, 2018
b864390
make listen dependency optional
eli-darkly Oct 31, 2018
789b5a4
readme
eli-darkly Oct 31, 2018
31a62c5
fix key handling and client integration, add tests
eli-darkly Oct 31, 2018
778cb6d
debugging
eli-darkly Nov 1, 2018
20dbef2
debugging
eli-darkly Nov 1, 2018
f1c00b1
add fallback polling logic, fix tests
eli-darkly Nov 1, 2018
198b843
rm debugging
eli-darkly Nov 1, 2018
c5d1823
debugging
eli-darkly Nov 2, 2018
9baffe3
debugging
eli-darkly Nov 2, 2018
4d81215
debugging
eli-darkly Nov 2, 2018
30d0cd2
debugging
eli-darkly Nov 2, 2018
8cb2ed9
comment correction
eli-darkly Nov 2, 2018
a10f973
documentation
eli-darkly Nov 2, 2018
16cf9c0
always use YAML parser
eli-darkly Nov 2, 2018
27d954e
report internal error that shouldn't happen
eli-darkly Nov 2, 2018
fd308a9
add test for multiple files
eli-darkly Nov 2, 2018
1d016bf
fix duplicate key checking (string vs. symbol problem)
eli-darkly Nov 2, 2018
c3e66d3
Don't use 'listen' in JRuby 9.1
eli-darkly Nov 2, 2018
1a36fd8
rm debugging
eli-darkly Nov 2, 2018
78ba815
better error handling in poll thread
eli-darkly Nov 2, 2018
2d29388
Merge pull request #82 from launchdarkly/eb/ch25289/file-source
eli-darkly Nov 2, 2018
38f534f
don't use Thread.raise to stop PollingProcessor thread; add test for …
eli-darkly Nov 2, 2018
4966136
Merge pull request #83 from launchdarkly/eb/ch19334/no-thread-raise
eli-darkly Nov 3, 2018
af2c98c
merge from public after release
LaunchDarklyCI Nov 3, 2018
457e85b
Merge branch 'master' of github.com:launchdarkly/ruby-client
eli-darkly Nov 5, 2018
4ad6a9b
merge from public after release
LaunchDarklyCI Nov 5, 2018
5a875c8
test on most recent patch version of each Ruby minor version
eli-darkly Dec 10, 2018
cf7d900
factor common logic out of RedisFeatureStore, add integrations module
eli-darkly Dec 15, 2018
4d34bc4
fix method reference
eli-darkly Dec 15, 2018
19182ad
misc cleanup
eli-darkly Dec 15, 2018
5941638
comment
eli-darkly Dec 15, 2018
b4cf610
re-add test file
eli-darkly Dec 15, 2018
3f9ef3b
misc cleanup
eli-darkly Dec 15, 2018
fa831f9
misc cleanup
eli-darkly Dec 15, 2018
ea68da4
initial DynamoDB implementation
eli-darkly Dec 15, 2018
bde2274
fix exception name
eli-darkly Dec 15, 2018
4e49317
fix test setup
eli-darkly Dec 15, 2018
c71bbec
comments
eli-darkly Dec 15, 2018
cfe3b18
readme
eli-darkly Dec 15, 2018
69cf890
fix doc comment
eli-darkly Dec 15, 2018
321eb6e
greatly improve documentation comments
eli-darkly Dec 15, 2018
5975954
comment fixes
eli-darkly Dec 15, 2018
414af99
change name of "update processor" to "data source"
eli-darkly Dec 15, 2018
c62c49e
Merge pull request #85 from launchdarkly/eb/ch28328/feature-store-sup…
eli-darkly Dec 18, 2018
81dcbf1
Merge pull request #86 from launchdarkly/eb/ch28328/dynamodb
eli-darkly Dec 18, 2018
216a1e8
Merge pull request #87 from launchdarkly/eb/docs
eli-darkly Dec 18, 2018
0fc71a8
Merge pull request #88 from launchdarkly/eb/data-source
eli-darkly Dec 18, 2018
fdb0291
default dynamodb_opts to {}
eli-darkly Dec 21, 2018
65ee009
fix Unicode handling in polling requests
eli-darkly Dec 21, 2018
86820ea
initial Consul implementation
eli-darkly Jan 3, 2019
485a73d
use new SSE gem
eli-darkly Jan 3, 2019
8567439
numerous Ruby SDK documentation fixes
eli-darkly Jan 4, 2019
63c3680
fix bundler version
eli-darkly Jan 4, 2019
008331b
fix build
eli-darkly Jan 4, 2019
c09c166
make some dependencies less strict and remove some unused ones
eli-darkly Jan 4, 2019
a4ced95
not using thread_safe
eli-darkly Jan 4, 2019
806bb8e
add bundler version (still not sure why we need to)
eli-darkly Jan 4, 2019
9d446c8
don't need bundler version for all rubies
eli-darkly Jan 4, 2019
5516745
fix bundler version again
eli-darkly Jan 4, 2019
54add1d
try to fix bundler version again
eli-darkly Jan 4, 2019
3d4b080
yet another build fix
eli-darkly Jan 5, 2019
635adf4
commit lock file to get correct bundler
eli-darkly Jan 5, 2019
3b5b08e
update lockfile
eli-darkly Jan 5, 2019
97bb302
Merge pull request #91 from launchdarkly/eb/ch29193/dependencies
eli-darkly Jan 5, 2019
5f28ecd
merge from public after release
eli-darkly Jan 5, 2019
b346917
Merge branch '5.4.x'
eli-darkly Jan 5, 2019
6342423
Merge branch 'eb/ruby-patch-versions' into eb/ch29137/sse-gem
eli-darkly Jan 5, 2019
e7f5f55
Merge branch 'master' into eb/ch29137/sse-gem
eli-darkly Jan 5, 2019
8656f25
use ruby-eventsource
eli-darkly Jan 6, 2019
1ced67e
uninstall unwanted bundler upgrade in CI
eli-darkly Jan 6, 2019
e11bf4b
allow net-http-persistent 3.x
eli-darkly Jan 6, 2019
cb2193e
uninstall unwanted bundler upgrade in CI
eli-darkly Jan 6, 2019
4b1167a
Merge branch '5.4.x' into eb/net-http-version
eli-darkly Jan 6, 2019
3f4e432
rewrite requestor without Faraday - don't have proxy yet
eli-darkly Jan 7, 2019
b250437
reduce intermittent HTTP errors on stub server by not reusing ports
eli-darkly Jan 7, 2019
c874db3
Merge branch 'master' into eb/ch25288/utf-8
eli-darkly Jan 7, 2019
5b4b855
fix charset handling
eli-darkly Jan 7, 2019
7a7c273
add test for proxy support, remove obsolete property
eli-darkly Jan 7, 2019
1502e61
rm duplicate test code
eli-darkly Jan 7, 2019
4857842
change event sending to use Net::HTTP; completely remove Faraday
eli-darkly Jan 7, 2019
277a0ce
Merge branch 'master' into eb/ch22514/docs
eli-darkly Jan 7, 2019
d658715
implement dependency ordering for feature store data
eli-darkly Jan 9, 2019
ed302ad
fix incomplete test
eli-darkly Jan 9, 2019
34c7418
Merge branch 'master' into eb/ch28430/consul
eli-darkly Jan 10, 2019
230a7f8
Merge pull request #94 from launchdarkly/eb/ch29137/sse-gem
eli-darkly Jan 10, 2019
065a348
Merge branch 'master' of github.com:launchdarkly/ruby-client
eli-darkly Jan 11, 2019
9d33cda
Merge branch 'master' of github.com:launchdarkly/ruby-client into 5.4.x
eli-darkly Jan 11, 2019
f18794d
Merge branch '5.4.x'
eli-darkly Jan 11, 2019
6be20c3
Merge branch 'master' into eb/ch22514/docs
eli-darkly Jan 11, 2019
f8b8d34
Merge branch 'master' into eb/ch29197/dependency-order
eli-darkly Jan 11, 2019
f8997d4
Merge branch 'master' into eb/no-faraday
eli-darkly Jan 11, 2019
8f6a68a
Merge branch 'master' into eb/ch25288/utf-8
eli-darkly Jan 15, 2019
8436be4
use Hash.first
eli-darkly Jan 15, 2019
aee1a3b
Merge pull request #93 from launchdarkly/eb/ch29197/dependency-order
eli-darkly Jan 15, 2019
23606bc
Merge pull request #89 from launchdarkly/eb/ch25288/utf-8
eli-darkly Jan 15, 2019
e84fbe7
add test for Unicode in feature store serialization
eli-darkly Jan 15, 2019
dd61579
Merge branch 'master' into eb/ch28430/consul
eli-darkly Jan 15, 2019
8920923
fill in the rest of the Consul implementation
eli-darkly Jan 15, 2019
21c79fe
minor doc fixes
eli-darkly Jan 15, 2019
7ea110f
rm debugging
eli-darkly Jan 15, 2019
5136187
fix initialized check
eli-darkly Jan 15, 2019
46ebc1f
improve feature store tests + minor Redis fixes
eli-darkly Jan 15, 2019
2a4064c
Merge pull request #95 from launchdarkly/eb/feature-store-unicode
eli-darkly Jan 16, 2019
7691723
Merge pull request #96 from launchdarkly/eb/ch28430/consul
eli-darkly Jan 16, 2019
97ee2da
test fix: we can't use Unicode in flag keys anyway
eli-darkly Jan 16, 2019
3061a42
Merge branch 'master' into eb/better-feature-store-tests
eli-darkly Jan 16, 2019
be4523c
Merge branch 'master' into eb/ch22514/docs
eli-darkly Jan 16, 2019
621ef03
Merge pull request #90 from launchdarkly/eb/ch22514/docs
eli-darkly Jan 16, 2019
dbbd033
Merge branch 'master' into eb/better-feature-store-tests
eli-darkly Jan 16, 2019
21a505e
test fix
eli-darkly Jan 16, 2019
9dcbda8
Merge pull request #97 from launchdarkly/eb/better-feature-store-tests
eli-darkly Jan 17, 2019
784eb07
misc prerelease fixes
eli-darkly Jan 17, 2019
a6490eb
merge from public after release
LaunchDarklyCI Jan 18, 2019
e9b06c6
fix doc comments
eli-darkly Jan 18, 2019
7812be4
merge from public after release
LaunchDarklyCI Jan 18, 2019
6389a26
add YARD config so our docs show up correctly everywhere
eli-darkly Jan 18, 2019
3406a03
don't need markup-provider option
eli-darkly Jan 18, 2019
2175108
Merge pull request #98 from launchdarkly/eb/ch17821/yard-config
eli-darkly Jan 18, 2019
76fa71e
merge from public after release
LaunchDarklyCI Jan 18, 2019
207e8fd
Merge branch 'master' into eb/no-faraday
eli-darkly Jan 29, 2019
d38973a
rm obsolete proxy param
eli-darkly Jan 29, 2019
0405d3d
Merge pull request #92 from launchdarkly/eb/no-faraday
eli-darkly Jan 29, 2019
def22fc
remove net-http-persistent
eli-darkly Jan 31, 2019
f5ef9a4
fix concurrent-ruby usage that breaks on Windows
eli-darkly Jan 31, 2019
e725a2c
Merge pull request #99 from launchdarkly/eb/ch30984/no-http-persistent
eli-darkly Feb 1, 2019
d4081a9
Merge pull request #100 from launchdarkly/eb/ch30999/atomic-value
eli-darkly Feb 1, 2019
9b4d75b
add pipeline and clean up with with rm_rf instead of rm
hroederld Feb 4, 2019
09ee839
Merge pull request #101 from launchdarkly/hr/azure2
hroederld Feb 4, 2019
eb4ad97
fix highlight blocks
hroederld Feb 4, 2019
d1190f5
Merge pull request #102 from launchdarkly/hr/blockfix
hroederld Feb 4, 2019
4aa6272
Hr/azure3 (#103)
hroederld Feb 5, 2019
fd143d7
add dynamo (#104)
hroederld Feb 5, 2019
e8860ba
Merge branch 'master' of github.com:launchdarkly/ruby-client
eli-darkly Feb 14, 2019
6a20ff1
add experimentation event overrides for rules and fallthrough
eli-darkly Feb 22, 2019
12f541a
warn & don't send event if identify or track has no valid user
eli-darkly Feb 22, 2019
2800db8
include user in prereq flag events
eli-darkly Feb 22, 2019
47106d9
rm unnecessary logic
eli-darkly Feb 26, 2019
763a222
more factory methods
eli-darkly Feb 26, 2019
0d0086b
Merge pull request #107 from launchdarkly/eb/ch32577/prereq-event-user
eli-darkly Mar 1, 2019
0cbb8cd
Merge branch 'experiment' into eb/ch32304/experiment
eli-darkly Mar 2, 2019
70cacc9
Merge pull request #106 from launchdarkly/eb/ch32176-ch31956/bad-user
eli-darkly Mar 5, 2019
1c7a349
Merge pull request #105 from launchdarkly/eb/ch32304/experiment
eli-darkly Mar 5, 2019
4c23461
update readme to refer to docs
bwoskow-ld Mar 6, 2019
43d39c0
Merge pull request #108 from launchdarkly/bw/ch33438/update-readme-to…
bwoskow-ld Mar 8, 2019
0f91442
Merge commit '72ba633b4f9b34507b5aaad61d0e0541e83df3ad'
eli-darkly Mar 13, 2019
232f419
add Ruby 2.6.2 to CI
eli-darkly Mar 20, 2019
20d109b
fix missing require for net/http
eli-darkly Mar 20, 2019
9e218c2
Merge pull request #109 from launchdarkly/eb/ch34549/net-http-name-error
eli-darkly Mar 21, 2019
ef0f819
merge from public after release
LaunchDarklyCI Mar 21, 2019
651dc37
stringify built-in user attributes in events, and secondary key for e…
eli-darkly Mar 28, 2019
da15bdd
make const names consistent
eli-darkly Mar 28, 2019
ecf18b2
Merge pull request #110 from launchdarkly/eb/ch35206/secondary-string
eli-darkly Mar 29, 2019
3b6bde7
merge from public after release
LaunchDarklyCI Mar 29, 2019
37f9757
Merge pull request #111 from launchdarkly/eb/ch34550/ruby-2.6
eli-darkly Apr 9, 2019
260bd1b
support metric value with track()
eli-darkly Apr 13, 2019
703ffe5
update method description
eli-darkly Apr 17, 2019
8cd7615
Merge pull request #112 from launchdarkly/eb/ch32304/metric-value
eli-darkly Apr 17, 2019
4bc671b
applying markdown templates and updating repository url references
bwoskow-ld May 6, 2019
a56ee20
Cleaning up markdown files
bwoskow-ld May 7, 2019
2bafe25
Merge pull request #114 from launchdarkly/bw/ch36771/applying-markdow…
eli-darkly May 9, 2019
962e729
allow skipping database tests
eli-darkly May 9, 2019
e044e81
Merge pull request #116 from launchdarkly/eb/ch37610/skip-db-tests
eli-darkly May 9, 2019
ca2f8ed
merge from public after release
LaunchDarklyCI May 10, 2019
f32b9c6
Updating the package name (#115)
bwoskow-ld May 13, 2019
650d24c
Merge branch 'master' of github.com:launchdarkly/ruby-server-sdk
bwoskow-ld May 13, 2019
746ebda
merge from public after release
LaunchDarklyCI May 13, 2019
8defb30
bump ld-eventsource version for stream logging fix
eli-darkly Jul 11, 2019
e7d27e2
Merge pull request #117 from launchdarkly/eb/ch40932/ioerror-log
eli-darkly Jul 11, 2019
8707138
merge from public after release
LaunchDarklyCI Jul 11, 2019
ed0c110
Merge branch 'master' of github.com:launchdarkly/ruby-client
eli-darkly Jul 23, 2019
f1e5b38
merge from public after release
LaunchDarklyCI Jul 23, 2019
c1aeaa3
use YAML.safe_load
eli-darkly Jul 24, 2019
f8aac44
add unit test and temporarily revert fix to demonstrate failure
eli-darkly Jul 24, 2019
8f48060
restore fix
eli-darkly Jul 24, 2019
b5af713
Merge pull request #118 from launchdarkly/eb/ch44118/safe-yaml
eli-darkly Jul 24, 2019
8fa005f
add comment about not using FileDataSource in production
eli-darkly Jul 24, 2019
6a89b0f
Merge pull request #119 from launchdarkly/eb/file-data-warning
eli-darkly Jul 24, 2019
c1bcd04
merge from public after release
LaunchDarklyCI Jul 24, 2019
bb543ad
merge from public after release
LaunchDarklyCI Jul 25, 2019
963e4eb
drop events if inbox is full
eli-darkly Jul 25, 2019
26933ab
Merge pull request #120 from launchdarkly/eb/ch42975/event-bottleneck
eli-darkly Jul 26, 2019
039efed
merge from public after release
LaunchDarklyCI Aug 5, 2019
77acf35
Merge branch 'master' into experiment
eli-darkly Aug 19, 2019
f0581a0
update doc comment for track with metric_value
eli-darkly Aug 19, 2019
c4c2cc1
Merge branch 'master' of github.com:launchdarkly/ruby-client
eli-darkly Aug 19, 2019
c742fda
Merge branch 'master' of github.com:launchdarkly/ruby-server-sdk
eli-darkly Aug 19, 2019
f8622a7
Merge pull request #121 from launchdarkly/eb/ch32304/track-comment
eli-darkly Aug 19, 2019
162b0fe
Merge branch 'master' of github.com:launchdarkly/ruby-server-sdk
eli-darkly Aug 19, 2019
032cd5e
Merge branch 'master' into experiment
eli-darkly Aug 20, 2019
1b25d98
Merge branch 'master' of github.com:launchdarkly/ruby-server-sdk
eli-darkly Aug 20, 2019
e3bd340
Merge branch 'master' of github.com:launchdarkly/ruby-server-sdk
eli-darkly Aug 29, 2019
db27402
Merge branch 'master' of github.com:launchdarkly/ruby-server-sdk
eli-darkly Nov 1, 2019
62518e4
Merge branch 'master' of github.com:launchdarkly/ruby-server-sdk
bwoskow-ld Nov 7, 2019
7620721
don't let user fall outside of last bucket in rollout
eli-darkly Dec 30, 2019
4abded2
Merge pull request #122 from launchdarkly/eb/ch43307/bucketing-fix
eli-darkly Jan 7, 2020
0c90251
merge from public after release
LaunchDarklyCI Jan 7, 2020
1cfcd52
add event payload ID header
eli-darkly Jan 15, 2020
640387c
Merge pull request #128 from launchdarkly/eb/ch61092/event-payload-id
eli-darkly Jan 15, 2020
5e91fe0
merge from public after release
LaunchDarklyCI Jan 15, 2020
4aaf75e
remove Rake dependency
eli-darkly Mar 9, 2020
441a195
update ld-eventsource to 1.0.2 which doesn't have Rake dependency
eli-darkly Mar 10, 2020
df631a7
Merge pull request #131 from launchdarkly/eb/ch68263/no-rake
eli-darkly Mar 10, 2020
602c5e6
implement diagnostic events in Ruby (#130)
eli-darkly Mar 10, 2020
b6566e2
merge from public after release
LaunchDarklyCI Mar 10, 2020
ddfbd17
update ruby-eventsource to 1.0.3 for backoff bug
eli-darkly Mar 18, 2020
4d6f9b5
Merge pull request #132 from launchdarkly/eb/ch69559/eventsource-fix
eli-darkly Mar 18, 2020
b53a212
merge from public after release
LaunchDarklyCI Mar 18, 2020
1fe77bb
fix incorrect initialization of EventProcessor
eli-darkly Mar 27, 2020
87a3f35
Merge pull request #133 from launchdarkly/eb/ch71287/broken-events
eli-darkly Mar 27, 2020
a4280d7
merge from public after release
LaunchDarklyCI Mar 27, 2020
6f0e1e5
remove install-time openssl check that breaks if you don't have rake
eli-darkly Apr 27, 2020
e35f8ab
treat comparison with wrong data type as a non-match, not an exceptio…
eli-darkly Apr 27, 2020
3e55dc4
fail fast for nil SDK key when appropriate
eli-darkly Apr 27, 2020
93112f5
Merge pull request #135 from launchdarkly/eb/ch74874/remove-openssl-c…
eli-darkly Apr 27, 2020
78e7496
Merge pull request #136 from launchdarkly/eb/ch73982/nil-sdk-key
eli-darkly Apr 27, 2020
dcacf1c
merge from public after release
LaunchDarklyCI Apr 27, 2020
ad7cd7f
tolerate nil value for user.custom (#137)
eli-darkly May 4, 2020
3b152d7
merge from public after release
LaunchDarklyCI May 4, 2020
4ca5ad3
Only shutdown the Redis pool if it is owned by the SDK (#158)
jacobthemyth May 27, 2020
60279fe
Merge branch 'contrib' of github.com:launchdarkly/ruby-server-sdk
eli-darkly May 27, 2020
06d55d5
improve doc comment
eli-darkly May 27, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions lib/ldclient-rb/impl/integrations/redis_impl.rb
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,8 @@ def initialize(opts)
@pool = opts[:pool] || ConnectionPool.new(size: max_connections) do
::Redis.new(@redis_opts)
end
# shutdown pool on close unless the client passed a custom pool and specified not to shutdown
@pool_shutdown_on_close = (!opts[:pool] || opts.fetch(:pool_shutdown_on_close, true))
@prefix = opts[:prefix] || LaunchDarkly::Integrations::Redis::default_prefix
@logger = opts[:logger] || Config.default_logger
@test_hook = opts[:test_hook] # used for unit tests, deliberately undocumented
Expand Down Expand Up @@ -118,6 +120,7 @@ def initialized_internal?

def stop
if @stopped.make_true
return unless @pool_shutdown_on_close
@pool.shutdown { |redis| redis.close }
end
end
Expand Down
3 changes: 3 additions & 0 deletions lib/ldclient-rb/integrations/redis.rb
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,9 @@ def self.default_prefix
# @option opts [Integer] :expiration (15) expiration time for the in-memory cache, in seconds; 0 for no local caching
# @option opts [Integer] :capacity (1000) maximum number of items in the cache
# @option opts [Object] :pool custom connection pool, if desired
# @option opts [Boolean] :pool_shutdown_on_close whether calling `close` should shutdown the custom connection pool;
# this is true by default, and should be set to false only if you are managing the pool yourself and want its
# lifecycle to be independent of the SDK client
# @return [LaunchDarkly::Interfaces::FeatureStore] a feature store object
#
def self.new_feature_store(opts)
Expand Down
1 change: 1 addition & 0 deletions lib/ldclient-rb/redis_store.rb
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ class RedisFeatureStore
# @option opts [Integer] :expiration expiration time for the in-memory cache, in seconds; 0 for no local caching
# @option opts [Integer] :capacity maximum number of feature flags (or related objects) to cache locally
# @option opts [Object] :pool custom connection pool, if desired
# @option opts [Boolean] :pool_shutdown_on_close whether calling `close` should shutdown the custom connection pool.
#
def initialize(opts = {})
core = LaunchDarkly::Impl::Integrations::Redis::RedisFeatureStoreCore.new(opts)
Expand Down
37 changes: 33 additions & 4 deletions spec/redis_feature_store_spec.rb
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
require "connection_pool"
require "feature_store_spec_base"
require "json"
require "redis"
Expand Down Expand Up @@ -27,11 +28,11 @@ def clear_all_data

describe LaunchDarkly::RedisFeatureStore do
subject { LaunchDarkly::RedisFeatureStore }

break if ENV['LD_SKIP_DATABASE_TESTS'] == '1'

# These tests will all fail if there isn't a Redis instance running on the default port.

context "real Redis with local cache" do
include_examples "feature_store", method(:create_redis_store), method(:clear_all_data)
end
Expand Down Expand Up @@ -59,7 +60,7 @@ def make_concurrent_modifier_test_hook(other_client, flag, start_version, end_ve
flag = { key: "foo", version: 1 }
test_hook = make_concurrent_modifier_test_hook(other_client, flag, 2, 4)
store = create_redis_store({ test_hook: test_hook })

begin
store.init(LaunchDarkly::FEATURES => { flag[:key] => flag })

Expand All @@ -77,7 +78,7 @@ def make_concurrent_modifier_test_hook(other_client, flag, start_version, end_ve
flag = { key: "foo", version: 1 }
test_hook = make_concurrent_modifier_test_hook(other_client, flag, 3, 3)
store = create_redis_store({ test_hook: test_hook })

begin
store.init(LaunchDarkly::FEATURES => { flag[:key] => flag })

Expand All @@ -89,4 +90,32 @@ def make_concurrent_modifier_test_hook(other_client, flag, start_version, end_ve
other_client.close
end
end

it "shuts down a custom Redis pool by default" do
unowned_pool = ConnectionPool.new(size: 1, timeout: 1) { Redis.new({ url: "redis://localhost:6379" }) }
store = create_redis_store({ pool: unowned_pool })

begin
store.init(LaunchDarkly::FEATURES => { })
store.stop

expect { unowned_pool.with {} }.to raise_error(ConnectionPool::PoolShuttingDownError)
ensure
unowned_pool.shutdown { |conn| conn.close }
end
end

it "doesn't shut down a custom Redis pool if pool_shutdown_on_close = false" do
unowned_pool = ConnectionPool.new(size: 1, timeout: 1) { Redis.new({ url: "redis://localhost:6379" }) }
store = create_redis_store({ pool: unowned_pool, pool_shutdown_on_close: false })

begin
store.init(LaunchDarkly::FEATURES => { })
store.stop

expect { unowned_pool.with {} }.not_to raise_error(ConnectionPool::PoolShuttingDownError)
ensure
unowned_pool.shutdown { |conn| conn.close }
end
end
end