Skip to content
This repository has been archived by the owner on May 30, 2024. It is now read-only.

prepare 5.10.0 release #273

Merged
merged 1,105 commits into from
Jul 29, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
1105 commits
Select commit Hold shift + click to select a range
01df1f3
Merge pull request #249 from launchdarkly/eb/ch77594/coverage-5-misc
eli-darkly Jun 2, 2020
ff3d3d1
Merge pull request #250 from launchdarkly/eb/ch76824/classpath-file
eli-darkly Jun 2, 2020
d219b44
Merge branch 'master' into eb/ch78216/test-data
eli-darkly Jun 2, 2020
fa2b39c
misc fixes/tests
eli-darkly Jun 2, 2020
705d25b
use java-sdk-common 1.0.0
eli-darkly Jun 2, 2020
2a44530
use okhttp-eventsource 2.3.0
eli-darkly Jun 2, 2020
9d23a88
Merge branch 'master' of github.com:launchdarkly/java-server-sdk
eli-darkly Jun 2, 2020
ddd886a
use okhttp-eventsource 2.3.1 for thread fix
eli-darkly Jun 18, 2020
6374424
Merge pull request #252 from launchdarkly/eb/ch80009/eventsource-thread
eli-darkly Jun 19, 2020
6fb600d
fix flaky tests due to change in EventSource error reporting
eli-darkly Jun 19, 2020
e22d43f
Merge pull request #253 from launchdarkly/eb/ch80009/flaky-test
eli-darkly Jun 19, 2020
8642c8b
merge from public after release
LaunchDarklyCI Jun 19, 2020
8873f44
remove support for indirect put and indirect patch
eli-darkly Jun 23, 2020
9a034e2
Merge pull request #254 from launchdarkly/eb/ch80666/no-indirect-patch
eli-darkly Jun 23, 2020
0293f58
fix typo in javadoc example code
eli-darkly Jun 24, 2020
8a08fc7
Merge pull request #255 from launchdarkly/eb/ch80837/javadoc-typo
eli-darkly Jun 24, 2020
4ad9351
clean up polling logic, fix status updating after an outage, don't re…
eli-darkly Jun 25, 2020
f14119a
merge from public after release
LaunchDarklyCI Jun 25, 2020
d41ae6c
slightly change semantics of boolean setters, improve tests, misc cle…
eli-darkly Aug 4, 2020
378b8e8
avoid NPEs if LDUser was deserialized by Gson (#257)
eli-darkly Aug 4, 2020
4836ea3
fix release metadata
eli-darkly Aug 5, 2020
96e58e7
prepare 4.14.1 release (#200)
LaunchDarklyCI Aug 5, 2020
22149a9
Releasing version 4.14.1
LaunchDarklyCI Aug 5, 2020
2d0d5cd
merge from public after release
LaunchDarklyCI Aug 5, 2020
ef8a801
Merge branch '4.x'
eli-darkly Aug 5, 2020
8825a48
exclude Kotlin metadata from jar + fix misc Gradle problems
eli-darkly Aug 18, 2020
ae46e03
Merge pull request #258 from launchdarkly/eb/ch87032/kotlin-symbols
eli-darkly Aug 18, 2020
b7ce928
merge from public after release
LaunchDarklyCI Aug 19, 2020
b32abc3
update CI and Gradle to test with newer JDKs (#259)
eli-darkly Aug 24, 2020
eefc460
update okhttp to 3.14.9 (fixes incompatibility with OpenJDK 8.0.252)
eli-darkly Aug 31, 2020
87120a4
Merge pull request #260 from launchdarkly/eb/ch88298/okhttp-update-4.x
eli-darkly Sep 1, 2020
0403392
prepare 4.14.2 release (#205)
LaunchDarklyCI Sep 1, 2020
2daeb92
Releasing version 4.14.2
LaunchDarklyCI Sep 1, 2020
7c09c6a
merge from public after release
LaunchDarklyCI Sep 1, 2020
7a9772c
Merge branch '4.x'
eli-darkly Sep 1, 2020
f3f01ec
update okhttp to 4.8.1 (fixes incompatibility with OpenJDK 8.0.252)
eli-darkly Sep 1, 2020
7025ae7
Merge pull request #261 from launchdarkly/eb/ch88298/okhttp-update-5.x
eli-darkly Sep 1, 2020
d1e311e
merge from public after release
LaunchDarklyCI Sep 1, 2020
f5a8555
gitignore
eli-darkly Sep 1, 2020
52c36be
Merge branch 'master' of github.com:launchdarkly/java-server-sdk
gwhelanLD Sep 3, 2020
9fe8f5b
merge from public after release
LaunchDarklyCI Sep 3, 2020
ac9bdb1
Bump SnakeYAML from 1.19 to 1.26 to address CVE-2017-18640
ssrm Sep 3, 2020
d1e0637
Merge pull request #262 from launchdarkly/eb/ch88108/snakeyaml-update
eli-darkly Sep 3, 2020
4f8f980
prepare 4.14.3 release (#209)
LaunchDarklyCI Sep 3, 2020
a6777a8
Releasing version 4.14.3
LaunchDarklyCI Sep 3, 2020
89954b5
merge from public after release
LaunchDarklyCI Sep 3, 2020
a83942e
Merge branch '4.x'
eli-darkly Sep 3, 2020
326e8e1
Merge branch 'master' into eb/ch78216/test-data
eli-darkly Sep 4, 2020
b800f23
comments
eli-darkly Sep 4, 2020
7cb20cd
Merge pull request #251 from launchdarkly/eb/ch78216/test-data
eli-darkly Sep 4, 2020
06fdd3e
only log initialization message once in polling mode
eli-darkly Sep 4, 2020
03e2ad8
Merge pull request #263 from launchdarkly/eb/ch88859/polling-logging
eli-darkly Sep 4, 2020
a448abc
merge from public after release
LaunchDarklyCI Sep 4, 2020
078fe16
[ch89935] Correct some logging call format strings (#264)
gwhelanLD Sep 17, 2020
136eb1b
[ch90109] Remove outdated trackMetric comment from before service sup…
gwhelanLD Sep 18, 2020
889a1c6
Fix compatibility with Java 7.
gwhelanLD Sep 25, 2020
67dea95
Remove import that is no longer used.
gwhelanLD Sep 25, 2020
402b8fe
Merge pull request #266 from launchdarkly/gw/ch90182/fix-java-7-compat
eli-darkly Sep 28, 2020
ee5e212
add Java 7 build (#267)
eli-darkly Sep 28, 2020
cd60e6d
prepare 4.14.4 release (#214)
LaunchDarklyCI Sep 28, 2020
424c7d5
Releasing version 4.14.4
LaunchDarklyCI Sep 28, 2020
72ac981
merge from public after release
LaunchDarklyCI Sep 28, 2020
0113451
add and use getSocketFactory
hroederld Sep 28, 2020
346f655
alignment
hroederld Sep 28, 2020
305f555
add socketFactory to builder
hroederld Sep 28, 2020
7c2eea8
test socket factory builder
hroederld Sep 28, 2020
7f1d8c8
Merge branch '4.x'
eli-darkly Sep 28, 2020
8b51b95
preserve dummy CI config file when pushing to gh-pages (#271)
eli-darkly Sep 30, 2020
f6ae98e
fix concatenation when base URI has a context path (#270)
eli-darkly Oct 1, 2020
b33e5bf
fix shaded jar builds to exclude Jackson classes and not modify Jacks…
eli-darkly Oct 1, 2020
e4ba1cd
merge from public after release
LaunchDarklyCI Oct 1, 2020
18af928
add test httpClientCanUseCustomSocketFactory for DefaultFeatureRequestor
hroederld Oct 7, 2020
fa90fbf
add httpClientCanUseCustomSocketFactory() test for DefaultEventSender…
hroederld Oct 7, 2020
a0b7894
add httpClientCanUseCustomSocketFactory() test to StreamProcessorTest
hroederld Oct 7, 2020
9aeeaaa
merge in master and fix conflict
hroederld Oct 7, 2020
86a601e
pass URI to in customSocketFactory event test
hroederld Oct 9, 2020
ad21f51
[ch90672] Add socketFactory support to SDK
hroederld Oct 9, 2020
8919a07
make test less ambiguous
hroederld Oct 10, 2020
f1808d9
Merge pull request #272 from launchdarkly/hr/ch90672/socketfactory-te…
hroederld Oct 10, 2020
9b20c08
merge from public after release
LaunchDarklyCI Oct 10, 2020
d727737
copy rules to new FlagBuilder instances (#273)
bwoskow-ld Dec 1, 2020
51cb8cf
merge from public after release
LaunchDarklyCI Dec 2, 2020
ace4ad4
Bump guava version (#274)
bwoskow-ld Jan 6, 2021
f86c2c6
merge from public after release
LaunchDarklyCI Jan 15, 2021
88a2e8b
Removed the guides link
bwoskow-ld Feb 3, 2021
9f2ab7b
increment versions when loading file data, so FlagTracker will work (…
eli-darkly Feb 19, 2021
3ba8b90
merge from public after release
LaunchDarklyCI Feb 20, 2021
0d6e3c6
add ability to ignore duplicate keys in file data (#276)
eli-darkly Mar 9, 2021
148dcf1
merge from public after release
LaunchDarklyCI Mar 9, 2021
57e4dd2
add alias events (#278)
apache-hb Apr 5, 2021
89efd68
add validation of javadoc build to CI
eli-darkly Apr 8, 2021
385e79d
update commons-codec to 1.15 (#279)
eli-darkly Apr 8, 2021
aca7716
Merge branch 'master' of github.com:launchdarkly/java-server-sdk
eli-darkly Apr 8, 2021
d2b62d1
Merge pull request #280 from launchdarkly/eb/ch105283/check-javadoc
eli-darkly Apr 8, 2021
c53e39c
Add support for experiment rollouts
robertjneal Apr 8, 2021
378b7e3
add tests and use seed for allocating user to partition
robertjneal Apr 9, 2021
c84651c
test serialization and add check for isExperiment
robertjneal Apr 9, 2021
d0e30d2
Merge branch 'master' into rneal/ch101658/add-support-for-experiment-…
robertjneal Apr 14, 2021
b4190ad
fix PollingProcessorTest test race condition + other test issues (#282)
eli-darkly Apr 14, 2021
b26f704
Merge branch 'master' into rneal/ch101658/add-support-for-experiment-…
eli-darkly Apr 14, 2021
fbd6d16
use launchdarkly-java-sdk-common 1.1.0-alpha-expalloc.2
eli-darkly Apr 14, 2021
777b3f3
Update src/test/java/com/launchdarkly/sdk/server/EvaluatorTest.java
robertjneal Apr 14, 2021
99fba91
Update src/test/java/com/launchdarkly/sdk/server/EvaluatorTest.java
robertjneal Apr 14, 2021
2809609
Update src/test/java/com/launchdarkly/sdk/server/EvaluatorTest.java
robertjneal Apr 14, 2021
61ab96d
Update src/test/java/com/launchdarkly/sdk/server/EvaluatorTest.java
robertjneal Apr 14, 2021
d2b53a3
changes per code review comments
robertjneal Apr 15, 2021
4b787a9
Merge branch 'rneal/ch101658/add-support-for-experiment-rollouts' of …
robertjneal Apr 15, 2021
47b9ebb
Please enter the commit message for your changes. Lines starting
robertjneal Apr 15, 2021
3903d54
fix null pointer exception
robertjneal Apr 16, 2021
112f052
address code review comments
robertjneal Apr 19, 2021
4765c66
address more comments
robertjneal Apr 19, 2021
12ee439
missed a ! for isUntracked()
robertjneal Apr 19, 2021
9ed9b2c
fix default boolean for json
robertjneal Apr 19, 2021
d651d26
make untracked FALSE by default
robertjneal Apr 19, 2021
176d7ce
refactoring of bucketing logic to remove the need for an extra result…
eli-darkly Apr 20, 2021
de65f7b
add comment to enum
robertjneal Apr 20, 2021
20e2916
Merge branch 'rneal/ch101658/add-support-for-experiment-rollouts' of …
robertjneal Apr 20, 2021
c05a64a
Merge pull request #281 from launchdarkly/rneal/ch101658/add-support-…
robertjneal Apr 20, 2021
d8c06ec
various JSON fixes, update common-sdk (#284)
eli-darkly Apr 22, 2021
cd8461e
merge from public after release
LaunchDarklyCI Apr 22, 2021
0991ed8
Merge branch 'master' of github.com:launchdarkly/java-server-sdk
eli-darkly Apr 23, 2021
95440c7
simlpify the logic and make it match node/.Net sdks
robertjneal Jun 1, 2021
f695931
Merge branch 'master' into exp-alloc
robertjneal Jun 1, 2021
bf3c9c5
Update src/main/java/com/launchdarkly/sdk/server/EventFactory.java
robertjneal Jun 1, 2021
ee1268b
add the same comment as the Node SDK
robertjneal Jun 2, 2021
abb667c
Merge pull request #285 from launchdarkly/rneal/ch107295/simplify-log…
robertjneal Jun 3, 2021
58367e0
Remove outdated/meaningless doc comment. (#286)
gwhelanLD Jun 9, 2021
72c3096
protect against NPEs if flag/segment JSON contains a null value
eli-darkly Jun 10, 2021
44a25fb
Merge pull request #287 from launchdarkly/eb/ch111218/tolerate-nulls
eli-darkly Jun 10, 2021
040909c
merge from public after release
LaunchDarklyCI Jun 11, 2021
c944996
Merge branch 'exp-alloc'
eli-darkly Jun 17, 2021
c5ad21b
use java-sdk-common 1.2.0
eli-darkly Jun 17, 2021
01f642f
fix Jackson-related build issues (again) (#288)
eli-darkly Jun 18, 2021
75322c2
merge from public after release
LaunchDarklyCI Jun 18, 2021
2d6ac72
update to okhttp-eventsource patch for stream retry bug, improve test…
eli-darkly Jun 24, 2021
093a350
merge from public after release
LaunchDarklyCI Jun 25, 2021
4b847a5
add public builder for FeatureFlagsState (#290)
eli-darkly Jun 25, 2021
b66328d
clarify FileData doc comment to say you shouldn't use offline mode (#…
eli-darkly Jun 25, 2021
04b9db7
improve validation of SDK key so we won't throw an exception that con…
eli-darkly Jul 2, 2021
721f757
fix javadoc link in FileData comment (#294)
eli-darkly Jul 2, 2021
2e1b210
fix PollingProcessor 401 behavior and use new HTTP test helpers (#292)
eli-darkly Jul 2, 2021
5de97b5
Merge branch 'master' of github.com:launchdarkly/java-server-sdk
eli-darkly Jul 2, 2021
81dd734
merge from public after release
LaunchDarklyCI Jul 2, 2021
eac6da8
re-fix metadata to remove Jackson dependencies, also remove Class-Pat…
eli-darkly Jul 8, 2021
dd7f414
merge from public after release
LaunchDarklyCI Jul 8, 2021
8db8a2d
make FeatureFlagsState.Builder.build() public (#297)
eli-darkly Aug 9, 2021
767e3ac
merge from public after release
Aug 9, 2021
69aef50
clean up tests using java-test-helpers 1.1.0 (#296)
eli-darkly Aug 13, 2021
dda1025
use Releaser v2 config + newer CI images (#298)
eli-darkly Sep 21, 2021
d7358f0
[ch123129] Fix `PollingDataSourceBuilder` example. (#299)
gwhelanLD Sep 24, 2021
f93e43b
Updates docs URLs
ember-stevens Sep 24, 2021
bcbb31b
Merge pull request #300 from launchdarkly/emberstevens/sc-118589/url-…
ember-stevens Sep 27, 2021
ac2fef7
always use US locale when parsing HTTP dates
eli-darkly Oct 12, 2021
4210dc9
Merge pull request #301 from launchdarkly/eb/sc-126069/http-date-locale
eli-darkly Oct 12, 2021
b3b1612
merge from public after release
Oct 12, 2021
b2bd379
use Gson 2.8.9
eli-darkly Nov 30, 2021
239395f
Merge pull request #302 from launchdarkly/eb/sc-132830/gson-version
eli-darkly Nov 30, 2021
b953d6d
merge from public after release
Nov 30, 2021
f34f3a3
don't try to send more diagnostic events after an unrecoverable HTTP …
eli-darkly Dec 7, 2021
c5ca59f
Merge pull request #303 from launchdarkly/eb/sc-133492/diagnostic-401
eli-darkly Dec 8, 2021
f5f4deb
merge from public after release
Dec 8, 2021
5416ac4
Merge branch 'master' of github.com:launchdarkly/java-server-sdk
eli-darkly Dec 8, 2021
c638922
ensure module-info file isn't copied into our jars during build
eli-darkly Jan 7, 2022
c04ad66
Merge pull request #305 from launchdarkly/eb/sc-136330/no-module-file
eli-darkly Jan 7, 2022
56acdd7
merge from public after release
Jan 7, 2022
f07c0e6
use Gradle 7
eli-darkly Jan 8, 2022
6339515
update build for benchmarks
eli-darkly Jan 8, 2022
4119fbc
more Gradle 7 compatibility changes for benchmark job
eli-darkly Jan 8, 2022
3af3fd4
Merge pull request #306 from launchdarkly/eb/sc-122485/gradle7
eli-darkly Jan 10, 2022
5c68abd
test with Java 17 in CI (#307)
eli-darkly Jan 10, 2022
3b60cdb
do date comparisons as absolute times, regardless of time zone (#310)
eli-darkly Jan 25, 2022
401a6c7
fix suppression of nulls in JSON representations (#311)
eli-darkly Jan 28, 2022
a6c79c2
fix identify/track null user key check, also don't create index event…
eli-darkly Jan 28, 2022
aee2487
use latest java-sdk-common
eli-darkly Jan 28, 2022
8f9a5c7
fix setting of trackEvents/trackReason in allFlagsState data when the…
eli-darkly Jan 28, 2022
b428765
Merge pull request #312 from launchdarkly/eb/sc-139100/event-fixes
eli-darkly Jan 28, 2022
5a4fb07
Merge pull request #313 from launchdarkly/eb/sc-137727/all-flag-exper…
eli-darkly Jan 28, 2022
cde4cc4
merge from public after release
Jan 29, 2022
6ff46e7
implement contract tests (#314)
eli-darkly Jan 29, 2022
5673244
Merge Big Segments feature branch for 5.7.0 release (#316)
gwhelanLD Jan 29, 2022
04018ae
merge from public after release
Jan 29, 2022
8a68142
Fix for pom including SDK common library as a dependency. (#317)
gwhelanLD Feb 4, 2022
977253b
merge from public after release
Feb 4, 2022
ee088db
use new logging API
eli-darkly Feb 15, 2022
48ba831
update readme notes about logging
eli-darkly Feb 15, 2022
b5ac0af
set base logger name for SDK per test
eli-darkly Feb 15, 2022
e539ce1
comment
eli-darkly Feb 15, 2022
c514d8e
javadoc fixes
eli-darkly Feb 15, 2022
7233793
revert accidental commit
eli-darkly Feb 15, 2022
75a4c8e
Upload JUnit XML to CircleCI on failure (#320)
aengelberg Apr 13, 2022
7612288
Add application tag support (#319)
aengelberg Apr 18, 2022
1865347
merge from public after release
Apr 18, 2022
ddf8945
Enforce 64 character limit on application tag values (#323)
aengelberg May 3, 2022
e2ac862
fix "wrong type" logic in evaluations when default value is null
eli-darkly May 3, 2022
9bc65b0
Merge pull request #324 from launchdarkly/eb/sc-151896/wrong-type-logic
eli-darkly May 3, 2022
2a71f4b
merge from public after release
May 4, 2022
e21e25a
Merge remote-tracking branch 'public/master'
aengelberg May 12, 2022
c24c950
Rename master to main in .ldrelease/config.yml (#325)
aengelberg May 19, 2022
19f92b0
Simpler way of setting base URIs in Java (#322)
aengelberg May 19, 2022
6483c4b
merge from public after release
May 26, 2022
98b6cd9
Merge branch 'main' into eb/sc-138971/logging
eli-darkly Jun 15, 2022
b617fc4
update logging info in readme
eli-darkly Jun 15, 2022
fe84a21
use 1.0.0 release of logging package
eli-darkly Jun 15, 2022
dce7097
misc cleanup
eli-darkly Jun 15, 2022
7bed7e5
remove unnecessary extra interfaces, just use default methods instead
eli-darkly Jun 15, 2022
6953613
make BigSegmentStoreWrapper.pollingDetectsStaleStatus test less timin…
eli-darkly Jun 15, 2022
96d1db2
make LDEndToEndClientTest.test____SpecialHttpConfigurations less timi…
eli-darkly Jun 15, 2022
81c04b1
Merge pull request #330 from launchdarkly/eb/sc-157098/flaky-tests
eli-darkly Jun 15, 2022
4aa8e6e
Merge pull request #331 from launchdarkly/eb/sc-157098/flaky-tests-2
eli-darkly Jun 15, 2022
27e58ba
make data source status tests less timing-sensitive
eli-darkly Jun 15, 2022
381b2f6
Merge pull request #332 from launchdarkly/eb/sc-157098/flaky-tests-3
eli-darkly Jun 15, 2022
1e197df
Merge branch 'logging' into eb/sc-138971/logging
eli-darkly Jun 15, 2022
a8448c3
use streaming JSON parsing for incoming LD data
eli-darkly Jun 26, 2022
2dfdaf7
fix tests
eli-darkly Jun 27, 2022
00388db
rm unused
eli-darkly Jun 27, 2022
505b9da
rm unused
eli-darkly Jun 27, 2022
7023c91
use okhttp-eventsource 2.6.0
eli-darkly Jun 29, 2022
9d9f1a4
update eventsource to 2.6.1 to fix pom/manifest problem
eli-darkly Jun 29, 2022
1ce875a
Merge pull request #334 from launchdarkly/eb/sc-157338/eventsource-st…
eli-darkly Jun 30, 2022
dff98fd
increase efficiency of summary event data structures (#335)
eli-darkly Jun 30, 2022
65361fc
merge from public after release
Jul 1, 2022
fadc01d
make reusable EvaluationDetail instances as part of flag preprocessin…
eli-darkly Jul 7, 2022
b41d1d0
make evaluator result object immutable and reuse instances
eli-darkly Jul 7, 2022
c6383a8
comment
eli-darkly Jul 7, 2022
3cad580
avoid creating List iterators during evaluations
eli-darkly Jul 8, 2022
681337e
remove unnecessary copy
eli-darkly Jul 8, 2022
1b8d842
Merge pull request #337 from launchdarkly/eb/sc-158936/reuse-eval-result
eli-darkly Jul 12, 2022
1c706cf
Merge pull request #338 from launchdarkly/eb/sc-158686/fewer-iterators
eli-darkly Jul 12, 2022
cc2eb70
fix allFlagsState to not generate prereq eval events
eli-darkly Jul 20, 2022
81d7d69
Merge pull request #352 from launchdarkly/eb/sc-158936/no-prereq-even…
eli-darkly Jul 20, 2022
d33a606
merge from public after release
Jul 21, 2022
1f75a5c
add "...ForAll" TestData methods to replace "...ForAllUsers"
eli-darkly Jul 27, 2022
d3b7487
bump okhttp & okhttp-eventsource dependencies
eli-darkly Jul 28, 2022
1cc6775
update comment to clarify that level() doesn't apply to SLF4J
eli-darkly Jul 28, 2022
caf0e10
update readme to mention different logging examples in hello-java
eli-darkly Jul 28, 2022
7617814
switch to use snapshot build of java-logging, pending next release
eli-darkly Jul 28, 2022
bc926fa
level setting does not apply to SLF4J and JUL
eli-darkly Jul 28, 2022
21cb4d3
Merge branch 'logging' into eb/sc-138971/logging
eli-darkly Jul 28, 2022
3a4d018
use java-logging 1.1.0 release
eli-darkly Jul 28, 2022
d5c7fdc
make sure META-INF files are never mistaken for classes and relocated
eli-darkly Jul 28, 2022
d99a841
Merge pull request #361 from launchdarkly/eb/sc-161764/okhttp-version
eli-darkly Jul 28, 2022
b3b2703
Merge branch 'main' into eb/sc-138971/logging
eli-darkly Jul 28, 2022
e4dc34d
merge from public after release
Jul 28, 2022
af39f39
Merge pull request #318 from launchdarkly/eb/sc-138971/logging
eli-darkly Jul 28, 2022
6a20188
Merge pull request #358 from launchdarkly/eb/sc-156598/testdata-metho…
eli-darkly Jul 28, 2022
5ad2095
update shared data store test logic to pass ClientContext with logger
eli-darkly Jul 28, 2022
ed818bc
Merge pull request #362 from launchdarkly/eb/sc-138971/store-tests-lo…
eli-darkly Jul 28, 2022
3a54988
enable external javadoc links for com.launchdarkly.logging types
eli-darkly Jul 28, 2022
bb26529
use variable for dependency version
eli-darkly Jul 28, 2022
7757812
Merge pull request #363 from launchdarkly/eb/sc-138971/logging-javado…
eli-darkly Jul 28, 2022
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
8 changes: 5 additions & 3 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -56,13 +56,15 @@ The project in the `benchmarks` subdirectory uses [JMH](https://openjdk.java.net

### Logging

Currently the SDK uses SLF4J for all log output. Here some things to keep in mind for good logging behavior:
The SDK uses a LaunchDarkly logging facade, [`com.launchdarkly.logging`](https://github.com/launchdarkly/java-logging). By default, this facade sends output to SLF4J.

Here some things to keep in mind for good logging behavior:

1. Stick to the standardized logger name scheme defined in `Loggers.java`, preferably for all log output, but definitely for all log output above `DEBUG` level. Logger names can be useful for filtering log output, so it is desirable for users to be able to reference a clear, stable logger name like `com.launchdarkly.sdk.server.LDClient.Events` rather than a class name like `com.launchdarkly.sdk.server.EventSummarizer` which is an implementation detail. The text of a log message should be distinctive enough that we can easily find which class generated the message.

2. Use parameterized messages (`Logger.MAIN.info("The value is {}", someValue)`) rather than string concatenation (`Logger.MAIN.info("The value is " + someValue)`). This avoids the overhead of string concatenation if the logger is not enabled for that level. If computing the value is an expensive operation, and it is _only_ relevant for logging, consider implementing that computation via a custom `toString()` method on some wrapper type so that it will be done lazily only if the log level is enabled.
2. Use parameterized messages (`logger.info("The value is {}", someValue)`) rather than string concatenation (`logger.info("The value is " + someValue)`). This avoids the overhead of string concatenation if the logger is not enabled for that level. If computing the value is an expensive operation, and it is _only_ relevant for logging, consider implementing that computation via a custom `toString()` method on some wrapper type so that it will be done lazily only if the log level is enabled.

3. Exception stacktraces should only be logged at debug level. For instance: `Logger.MAIN.warn("An error happened: {}", ex.toString()); Logger.MAIN.debug(ex.toString(), ex)`. Also, consider whether the stacktrace would be at all meaningful in this particular context; for instance, in a `try` block around a network I/O operation, the stacktrace would only tell us (a) some internal location in Java standard libraries and (b) the location in our own code where we tried to do the operation; (a) is very unlikely to tell us anything that the exception's type and message doesn't already tell us, and (b) could be more clearly communicated by just writing a specific log message.
3. There is a standard pattern for logging exceptions, using the `com.launchdarkly.logging.LogValues` helpers. First, log the basic description of the exception at whatever level is appropriate (`WARN` or `ERROR`): `logger.warn("An error happened: {}", LogValues.exceptionSummary(ex))`. Then, log a stack at debug level: `logger.debug(LogValues.exceptionTrace(ex))`. The `exceptionTrace` helper is lazily evaluated so that the stacktrace will only be computed if debug logging is actually enabled. However, consider whether the stacktrace would be at all meaningful in this particular context; for instance, in a `try` block around a network I/O operation, the stacktrace would only tell us (a) some internal location in Java standard libraries and (b) the location in our own code where we tried to do the operation; (a) is very unlikely to tell us anything that the exception's type and message doesn't already tell us, and (b) could be more clearly communicated by just writing a specific log message.

### Code coverage

Expand Down
8 changes: 7 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,13 @@ Refer to the [SDK reference guide](https://docs.launchdarkly.com/sdk/server-side

## Logging

The LaunchDarkly SDK uses [SLF4J](https://www.slf4j.org/). All loggers are namespaced under `com.launchdarkly`. For an example configuration check out the [hello-java](https://github.com/launchdarkly/hello-java) project.
By default, the LaunchDarkly SDK uses [SLF4J](https://www.slf4j.org/). SLF4J has its own configuration mechanisms for determining where output will go, and filtering by level and/or logger name.

The SDK can also be configured to use other adapters from the [com.launchdarkly.logging](https://github.com/launchdarkly/java-logging) facade instead of SLF4J. See `LoggingConfigurationBuilder`. This allows the logging behavior to be completely determined by the application, rather than by external SLF4J configuration.

For an example of using the default SLF4J behavior with a simple console logging configuration, check out the [`slf4j-logging` branch](https://github.com/launchdarkly/hello-java/tree/slf4j-logging) of the [`hello-java`](https://github.com/launchdarkly/hello-java) project. The [main branch](https://github.com/launchdarkly/hello-java) of `hello-java` uses console logging that is programmatically configured without SLF4J.

All loggers are namespaced under `com.launchdarkly`, if you are using name-based filtering.

Be aware of two considerations when enabling the DEBUG log level:
1. Debug-level logs can be very verbose. It is not recommended that you turn on debug logging in high-volume environments.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ public BenchmarkInputs() {
.dataStore(specificDataStore(dataStore))
.events(Components.noEvents())
.dataSource(Components.externalUpdatesOnly())
.logging(Components.noLogging())
.build();
client = new LDClient(SDK_KEY, config);

Expand Down
10 changes: 10 additions & 0 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ ext.versions = [
"guava": "30.1-jre",
"jackson": "2.11.2",
"launchdarklyJavaSdkCommon": "1.3.0",
"launchdarklyLogging": "1.1.0",
"okhttp": "4.9.3", // specify this for the SDK build instead of relying on the transitive dependency from okhttp-eventsource
"okhttpEventsource": "2.6.2",
"slf4j": "1.7.21",
Expand Down Expand Up @@ -131,6 +132,7 @@ libraries.internal = [
// also as package exports (i.e. it provides them if a newer version is not available
// from an import).
libraries.external = [
"com.launchdarkly:launchdarkly-logging:${versions.launchdarklyLogging}",
"org.slf4j:slf4j-api:${versions.slf4j}"
]

Expand Down Expand Up @@ -322,6 +324,14 @@ javadoc {
// Use test classpath so Javadoc won't complain about java-sdk-common classes that internally
// reference stuff we don't use directly, like Jackson
classpath = sourceSets.test.compileClasspath

// The following should allow hyperlinks to com.launchdarkly.logging classes to go to
// the correct external URLs
if (options instanceof StandardJavadocDocletOptions) {
(options as StandardJavadocDocletOptions).links(
"https://javadoc.io/doc/com.launchdarkly/launchdarkly-logging/${versions.launchdarklyLogging}"
)
}
}

// Force the Javadoc build to fail if there are any Javadoc warnings. See: https://discuss.gradle.org/t/javadoc-fail-on-warning/18141/3
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ public SdkClientEntity(TestService owner, CreateInstanceParams params) {
this.logger = LoggerFactory.getLogger(params.tag);
logger.info("Starting SDK client");

LDConfig config = buildSdkConfig(params.configuration);
LDConfig config = buildSdkConfig(params.configuration, params.tag);
this.client = new LDClient(params.configuration.credential, config);
if (!client.isInitialized() && !params.configuration.initCanFail) {
throw new RuntimeException("client initialization failed or timed out");
Expand Down Expand Up @@ -184,9 +184,11 @@ public void close() {
logger.info("Test ended");
}

private LDConfig buildSdkConfig(SdkConfigParams params) {
private LDConfig buildSdkConfig(SdkConfigParams params, String tag) {
LDConfig.Builder builder = new LDConfig.Builder();

builder.logging(Components.logging().baseLoggerName(tag + ".sdk"));

if (params.startWaitTimeMs != null) {
builder.startWait(Duration.ofMillis(params.startWaitTimeMs.longValue()));
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
import com.google.common.cache.CacheBuilder;
import com.google.common.cache.CacheLoader;
import com.google.common.cache.LoadingCache;
import com.launchdarkly.logging.LDLogger;
import com.launchdarkly.sdk.EvaluationReason.BigSegmentsStatus;
import com.launchdarkly.sdk.server.interfaces.BigSegmentStore;
import com.launchdarkly.sdk.server.interfaces.BigSegmentStoreStatusProvider.Status;
Expand All @@ -15,7 +16,6 @@

import org.apache.commons.codec.digest.DigestUtils;
import org.checkerframework.checker.nullness.qual.NonNull;
import org.slf4j.Logger;

import java.io.Closeable;
import java.io.IOException;
Expand All @@ -27,23 +27,23 @@
import java.util.concurrent.TimeUnit;

class BigSegmentStoreWrapper implements Closeable {
private static final Logger logger = Loggers.BIG_SEGMENTS;

private final BigSegmentStore store;
private final Duration staleAfter;
private final ScheduledFuture<?> pollFuture;
private final LoadingCache<String, Membership> cache;
private final EventBroadcasterImpl<StatusListener, Status> statusProvider;

private final LDLogger logger;
private final Object statusLock = new Object();
private Status lastStatus;

BigSegmentStoreWrapper(BigSegmentsConfiguration config,
EventBroadcasterImpl<StatusListener, Status> statusProvider,
ScheduledExecutorService sharedExecutor) {
ScheduledExecutorService sharedExecutor,
LDLogger logger) {
this.store = config.getStore();
this.staleAfter = config.getStaleAfter();
this.statusProvider = statusProvider;
this.logger = logger;

CacheLoader<String, Membership> loader = new CacheLoader<String, Membership>() {
@Override
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package com.launchdarkly.sdk.server;

import com.launchdarkly.sdk.server.interfaces.ApplicationInfo;
import com.launchdarkly.logging.LDLogger;
import com.launchdarkly.logging.Logs;
import com.launchdarkly.sdk.server.interfaces.BasicConfiguration;
import com.launchdarkly.sdk.server.interfaces.ClientContext;
import com.launchdarkly.sdk.server.interfaces.HttpConfiguration;
Expand Down Expand Up @@ -52,11 +53,35 @@ private ClientContextImpl(
ScheduledExecutorService sharedExecutor,
DiagnosticAccumulator diagnosticAccumulator
) {
this.basicConfiguration = new BasicConfiguration(sdkKey, configuration.offline, configuration.threadPriority, configuration.applicationInfo, configuration.serviceEndpoints);
// There is some temporarily over-elaborate logic here because the component factory interfaces can't
// be updated to make the dependencies more sensible till the next major version.
BasicConfiguration tempBasic = new BasicConfiguration(sdkKey, configuration.offline, configuration.threadPriority,
configuration.applicationInfo, configuration.serviceEndpoints, LDLogger.none());
this.loggingConfiguration = configuration.loggingConfigFactory.createLoggingConfiguration(tempBasic);
LDLogger baseLogger = LDLogger.withAdapter(
loggingConfiguration.getLogAdapter() == null ? Logs.none() : loggingConfiguration.getLogAdapter(),
loggingConfiguration.getBaseLoggerName() == null ? Loggers.BASE_LOGGER_NAME :
loggingConfiguration.getBaseLoggerName()
);

this.basicConfiguration = new BasicConfiguration(
sdkKey,
configuration.offline,
configuration.threadPriority,
configuration.applicationInfo,
configuration.serviceEndpoints,
baseLogger
);

this.httpConfiguration = configuration.httpConfigFactory.createHttpConfiguration(basicConfiguration);
this.loggingConfiguration = configuration.loggingConfigFactory.createLoggingConfiguration(basicConfiguration);



if (this.httpConfiguration.getProxy() != null) {
baseLogger.info("Using proxy: {} {} authentication.",
this.httpConfiguration.getProxy(),
this.httpConfiguration.getProxyAuthentication() == null ? "without" : "with");
}

this.sharedExecutor = sharedExecutor;

if (!configuration.diagnosticOptOut && diagnosticAccumulator != null) {
Expand Down
53 changes: 52 additions & 1 deletion src/main/java/com/launchdarkly/sdk/server/Components.java
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@

import static com.launchdarkly.sdk.server.ComponentsImpl.NULL_EVENT_PROCESSOR_FACTORY;

import com.launchdarkly.logging.LDLogAdapter;
import com.launchdarkly.logging.Logs;
import com.launchdarkly.sdk.server.ComponentsImpl.EventProcessorBuilderImpl;
import com.launchdarkly.sdk.server.ComponentsImpl.HttpBasicAuthentication;
import com.launchdarkly.sdk.server.ComponentsImpl.HttpConfigurationBuilderImpl;
Expand Down Expand Up @@ -316,14 +318,63 @@ public static HttpAuthentication httpBasicAuthentication(String username, String
* .build();
* </code></pre>
*
* @return a factory object
* @return a configuration builder
* @since 5.0.0
* @see LDConfig.Builder#logging(com.launchdarkly.sdk.server.interfaces.LoggingConfigurationFactory)
*/
public static LoggingConfigurationBuilder logging() {
return new LoggingConfigurationBuilderImpl();
}

/**
* Returns a configuration builder for the SDK's logging configuration, specifying the
* implementation of logging to use.
* <p>
* This is a shortcut for <code>Components.logging().adapter(logAdapter)</code>. The
* <a href="https://github.com/launchdarkly/java-logging"><code>com.launchdarkly.logging</code></a>
* API defines the {@link LDLogAdapter} interface to specify where log output should be sent. By default,
* it is set to {@link com.launchdarkly.logging.LDSLF4J#adapter()}, meaning that output will be sent to
* <a href="https://www.slf4j.org/">SLF4J</a> and controlled by the SLF4J configuration. You may use
* the {@link com.launchdarkly.logging.Logs} factory methods, or a custom implementation, to handle log
* output differently. For instance, you may specify {@link com.launchdarkly.logging.Logs#basic()} for
* simple console output, or {@link com.launchdarkly.logging.Logs#toJavaUtilLogging()} to use the
* <code>java.util.logging</code> framework.
* <p>
* Passing this to {@link LDConfig.Builder#logging(com.launchdarkly.sdk.server.interfaces.LoggingConfigurationFactory)},
* after setting any desired properties on the builder, applies this configuration to the SDK.
* <pre><code>
* LDConfig config = new LDConfig.Builder()
* .logging(
* Components.logging(Logs.basic())
* )
* .build();
* </code></pre>
*
* @param logAdapter the log adapter
* @return a configuration builder
* @since 5.10.0
* @see LDConfig.Builder#logging(com.launchdarkly.sdk.server.interfaces.LoggingConfigurationFactory)
* @see LoggingConfigurationBuilder#adapter(LDLogAdapter)
*/
public static LoggingConfigurationBuilder logging(LDLogAdapter logAdapter) {
return logging().adapter(logAdapter);
}

/**
* Returns a configuration builder that turns off SDK logging.
* <p>
* Passing this to {@link LDConfig.Builder#logging(com.launchdarkly.sdk.server.interfaces.LoggingConfigurationFactory)}
* applies this configuration to the SDK.
* <p>
* It is equivalent to <code>Components.logging(com.launchdarkly.logging.Logs.none())</code>.
*
* @return a configuration builder
* @since 5.10.0
*/
public static LoggingConfigurationBuilder noLogging() {
return logging().adapter(Logs.none());
}

/**
* Returns a configuration builder for the SDK's application metadata.
* <p>
Expand Down
Loading