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.5.4 release #130

Merged
merged 178 commits into from
Mar 21, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
178 commits
Select commit Hold shift + click to select a range
f5092af
Remove @ashanbrown from codeowners
ashanbrown Jul 24, 2018
fd63b2b
log exception stacktraces at debug level
eli-darkly Aug 2, 2018
d4be186
re-add minimal unit test
eli-darkly Aug 2, 2018
d73d66c
log exceptions at error level
eli-darkly Aug 2, 2018
94c8485
Merge pull request #75 from launchdarkly/eb/ch19339/exception-logging
eli-darkly Aug 2, 2018
ca15234
add new version of all_flags that captures more metadata
eli-darkly Aug 17, 2018
ed19523
add tests for FeatureFlagsState
eli-darkly Aug 17, 2018
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
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
0d0086b
Merge pull request #107 from launchdarkly/eb/ch32577/prereq-event-user
eli-darkly Mar 1, 2019
70cacc9
Merge pull request #106 from launchdarkly/eb/ch32176-ch31956/bad-user
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
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
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
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,8 @@ require 'ldclient-rb'
client = LaunchDarkly::LDClient.new("your_sdk_key")
```

*NOTE: Please refer to [our documentation](https://docs.launchdarkly.com/docs/ruby-sdk-reference#section-initializing-ldclient-using-spring-unicorn-or-puma) for additional instructions on how to use LaunchDarkly with [Spring](https://github.com/rails/spring), [Unicorn](https://bogomips.org/unicorn/), or [Puma](https://github.com/puma/puma).*

### Ruby on Rails

1. Add `gem 'ldclient-rb'` to your Gemfile and `bundle install`
Expand Down
3 changes: 2 additions & 1 deletion lib/ldclient-rb/evaluation.rb
Original file line number Diff line number Diff line change
Expand Up @@ -263,6 +263,7 @@ def check_prerequisites(flag, user, store, events, logger)
event = {
kind: "feature",
key: prereq_key,
user: user,
variation: prereq_res.variation_index,
value: prereq_res.value,
version: prereq_flag[:version],
Expand All @@ -272,7 +273,7 @@ def check_prerequisites(flag, user, store, events, logger)
}
events.push(event)
rescue => exn
Util.log_exception(logger, "Error evaluating prerequisite flag \"#{prereq_key}\" for flag \"{flag[:key]}\"", exn)
Util.log_exception(logger, "Error evaluating prerequisite flag \"#{prereq_key}\" for flag \"#{flag[:key]}\"", exn)
prereq_ok = false
end
end
Expand Down
8 changes: 8 additions & 0 deletions lib/ldclient-rb/ldclient.rb
Original file line number Diff line number Diff line change
Expand Up @@ -211,6 +211,10 @@ def variation_detail(key, user, default)
# @return [void]
#
def identify(user)
if !user || user[:key].nil?
@config.logger.warn("Identify called with nil user or nil user key!")
return
end
sanitize_user(user)
@event_processor.add_event(kind: "identify", key: user[:key], user: user)
end
Expand All @@ -229,6 +233,10 @@ def identify(user)
# @return [void]
#
def track(event_name, user, data)
if !user || user[:key].nil?
@config.logger.warn("Track called with nil user or nil user key!")
return
end
sanitize_user(user)
@event_processor.add_event(kind: "custom", key: event_name, user: user, data: data)
end
Expand Down
1 change: 1 addition & 0 deletions lib/ldclient-rb/util.rb
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
require "net/http"
require "uri"

module LaunchDarkly
Expand Down
8 changes: 4 additions & 4 deletions spec/evaluation_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,7 @@ def boolean_flag_with_clauses(clauses)
detail = LaunchDarkly::EvaluationDetail.new('b', 1,
{ kind: 'PREREQUISITE_FAILED', prerequisiteKey: 'feature1' })
events_should_be = [{
kind: 'feature', key: 'feature1', variation: nil, value: nil, version: 2, prereqOf: 'feature0',
kind: 'feature', key: 'feature1', user: user, variation: nil, value: nil, version: 2, prereqOf: 'feature0',
trackEvents: nil, debugEventsUntilDate: nil
}]
result = evaluate(flag, user, features, logger)
Expand Down Expand Up @@ -159,7 +159,7 @@ def boolean_flag_with_clauses(clauses)
detail = LaunchDarkly::EvaluationDetail.new('b', 1,
{ kind: 'PREREQUISITE_FAILED', prerequisiteKey: 'feature1' })
events_should_be = [{
kind: 'feature', key: 'feature1', variation: 1, value: 'e', version: 2, prereqOf: 'feature0',
kind: 'feature', key: 'feature1', user: user, variation: 1, value: 'e', version: 2, prereqOf: 'feature0',
trackEvents: nil, debugEventsUntilDate: nil
}]
result = evaluate(flag, user, features, logger)
Expand Down Expand Up @@ -189,7 +189,7 @@ def boolean_flag_with_clauses(clauses)
detail = LaunchDarkly::EvaluationDetail.new('b', 1,
{ kind: 'PREREQUISITE_FAILED', prerequisiteKey: 'feature1' })
events_should_be = [{
kind: 'feature', key: 'feature1', variation: 0, value: 'd', version: 2, prereqOf: 'feature0',
kind: 'feature', key: 'feature1', user: user, variation: 0, value: 'd', version: 2, prereqOf: 'feature0',
trackEvents: nil, debugEventsUntilDate: nil
}]
result = evaluate(flag, user, features, logger)
Expand Down Expand Up @@ -218,7 +218,7 @@ def boolean_flag_with_clauses(clauses)
user = { key: 'x' }
detail = LaunchDarkly::EvaluationDetail.new('a', 0, { kind: 'FALLTHROUGH' })
events_should_be = [{
kind: 'feature', key: 'feature1', variation: 1, value: 'e', version: 2, prereqOf: 'feature0',
kind: 'feature', key: 'feature1', user: user, variation: 1, value: 'e', version: 2, prereqOf: 'feature0',
trackEvents: nil, debugEventsUntilDate: nil
}]
result = evaluate(flag, user, features, logger)
Expand Down
9 changes: 0 additions & 9 deletions spec/fixtures/numeric_key_user.json

This file was deleted.

9 changes: 0 additions & 9 deletions spec/fixtures/sanitized_numeric_key_user.json

This file was deleted.

54 changes: 47 additions & 7 deletions spec/ldclient_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,8 @@
subject.new("secret", offline_config)
end
let(:null_data) { LaunchDarkly::NullUpdateProcessor.new }
let(:config) { LaunchDarkly::Config.new({send_events: false, data_source: null_data}) }
let(:logger) { double().as_null_object }
let(:config) { LaunchDarkly::Config.new({ send_events: false, data_source: null_data, logger: logger }) }
let(:client) do
subject.new("secret", config)
end
Expand All @@ -17,16 +18,31 @@
JSON.parse(data, symbolize_names: true)
end
let(:user) do
data = File.read(File.join("spec", "fixtures", "user.json"))
JSON.parse(data, symbolize_names: true)
{
key: "user@test.com",
custom: {
groups: [ "microsoft", "google" ]
}
}
end
let(:numeric_key_user) do
data = File.read(File.join("spec", "fixtures", "numeric_key_user.json"))
JSON.parse(data, symbolize_names: true)
{
key: 33,
custom: {
groups: [ "microsoft", "google" ]
}
}
end
let(:sanitized_numeric_key_user) do
data = File.read(File.join("spec", "fixtures", "sanitized_numeric_key_user.json"))
JSON.parse(data, symbolize_names: true)
{
key: "33",
custom: {
groups: [ "microsoft", "google" ]
}
}
end
let(:user_without_key) do
{ name: "Keyless Joe" }
end

def event_processor
Expand Down Expand Up @@ -342,6 +358,18 @@ def event_processor
expect(event_processor).to receive(:add_event).with(hash_including(user: sanitized_numeric_key_user))
client.track("custom_event_name", numeric_key_user, nil)
end

it "does not send an event, and logs a warning, if user is nil" do
expect(event_processor).not_to receive(:add_event)
expect(logger).to receive(:warn)
client.track("custom_event_name", nil, nil)
end

it "does not send an event, and logs a warning, if user key is nil" do
expect(event_processor).not_to receive(:add_event)
expect(logger).to receive(:warn)
client.track("custom_event_name", user_without_key, nil)
end
end

describe '#identify' do
Expand All @@ -354,6 +382,18 @@ def event_processor
expect(event_processor).to receive(:add_event).with(hash_including(user: sanitized_numeric_key_user))
client.identify(numeric_key_user)
end

it "does not send an event, and logs a warning, if user is nil" do
expect(event_processor).not_to receive(:add_event)
expect(logger).to receive(:warn)
client.identify(nil)
end

it "does not send an event, and logs a warning, if user key is nil" do
expect(event_processor).not_to receive(:add_event)
expect(logger).to receive(:warn)
client.identify(user_without_key)
end
end

describe 'with send_events: false' do
Expand Down