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 8.0.0 release #190

Merged
merged 534 commits into from
Dec 30, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
534 commits
Select commit Hold shift + click to select a range
a4fc092
Merge pull request #128 from launchdarkly/eb/ch65536/diag-events-warn…
eli-darkly Feb 12, 2020
02f5626
merge from public after release
LaunchDarklyCI Feb 12, 2020
ad248d6
make verify_ssl=False turn off certificate verification too (#129)
eli-darkly Mar 19, 2020
e754335
merge from public after release
LaunchDarklyCI Mar 20, 2020
b7d081b
add more TLS config options and collect HTTP/HTTPS config options in …
eli-darkly Mar 25, 2020
770fd71
make stream retry/backoff/jitter behavior consistent with other SDKs …
eli-darkly Mar 27, 2020
4016887
streams shouldn't use the same read timeout as the rest of the SDK (#…
eli-darkly Mar 30, 2020
f7ec18a
merge from public after release
LaunchDarklyCI Mar 30, 2020
02a803f
implement our own retry logic & logging for event posts, don't use ur…
eli-darkly May 9, 2020
50f2d94
remove support for indirect/patch and indirect/put
eli-darkly Jun 23, 2020
a246026
Merge pull request #134 from launchdarkly/eb/ch80666/no-indirect-patch
eli-darkly Jun 23, 2020
a9fe218
remove unused logic for individual flag/segment poll for indirect/patch
eli-darkly Jun 25, 2020
aaa9455
Merge pull request #135 from launchdarkly/eb/ch80666/no-indirect-patch
eli-darkly Jun 26, 2020
89fa623
merge from public after release
LaunchDarklyCI Jul 13, 2020
e1c93da
Ehaisley/84082/remove python2 (#136)
apache-hb Jul 30, 2020
3095315
Allow authenticating with proxy
gangeli Sep 15, 2020
eb7fc76
Merge pull request #145 from gangeli/master
eli-darkly Sep 16, 2020
14dfd8e
Merge branch 'contrib' of github.com:launchdarkly/python-server-sdk i…
eli-darkly Sep 16, 2020
1de0769
reimplement proxy tests for DRY and add test of proxy auth params
eli-darkly Sep 21, 2020
ed01be0
doc comment on auth params in proxy URL
eli-darkly Sep 16, 2020
6d98ae7
Merge pull request #137 from launchdarkly/eb/ch89791/proxy-auth-in-url
eli-darkly Sep 21, 2020
7bff994
Merge branch '6.x' of github.com:launchdarkly/python-server-sdk into 6.x
eli-darkly Sep 21, 2020
8d34668
merge from public after release
LaunchDarklyCI Sep 21, 2020
b5213b2
Merge branch '6.x'
eli-darkly Sep 22, 2020
c35fa61
add type hints to some of the public facing api.
apache-hb Sep 28, 2020
7745881
Revert "add type hints to some of the public facing api."
apache-hb Sep 28, 2020
43b4c31
Ehaisley/ch86857/type hints (#138)
apache-hb Oct 15, 2020
58b5bc3
remove all current deprecations (#139)
apache-hb Oct 27, 2020
b35ec6e
remove global set_sdk_key, make SDK key required in Config (#140)
eli-darkly Oct 27, 2020
5e3e5c5
Merge branch '6.x' of github.com:launchdarkly/python-server-sdk-private
eli-darkly Oct 28, 2020
3b904f3
merge from public after release
LaunchDarklyCI Oct 28, 2020
eb65618
Merge branch 'master' of github.com:launchdarkly/python-server-sdk
eli-darkly Oct 28, 2020
ebd092d
Merge branch 'master' of github.com:launchdarkly/python-server-sdk
eli-darkly Nov 25, 2020
528dc22
merge from public after release
LaunchDarklyCI Nov 26, 2020
e5f6450
Removed the guides link
bwoskow-ld Feb 3, 2021
4d2e999
Pinning mypy and running it against different python versions (#141)
bwoskow-ld Feb 5, 2021
1cc83f5
fix time zone mishandling that could make event debugging not work (#…
eli-darkly Feb 19, 2021
dc955d3
merge from public after release
LaunchDarklyCI Feb 19, 2021
5fa5966
fix 6.x build (#143)
eli-darkly Feb 23, 2021
c9d6ec6
fix time zone mishandling that could make event debugging not work (6…
eli-darkly Feb 23, 2021
f9ce3b9
prepare 6.13.3 release (#154)
LaunchDarklyCI Feb 23, 2021
953c126
Releasing version 6.13.3
LaunchDarklyCI Feb 23, 2021
faec38d
merge from public after release
LaunchDarklyCI Feb 23, 2021
b740df9
Merge branch '6.x'
eli-darkly Feb 24, 2021
532a01b
[ch99756] Add alias events (#145)
hroederld Mar 11, 2021
35227bf
merge from public after release
LaunchDarklyCI Mar 12, 2021
8c327d0
add support for experiment rollouts
robertjneal Apr 29, 2021
31c1c21
fix unit test
robertjneal Apr 29, 2021
f52ab39
address PR comments
robertjneal May 6, 2021
15f9a97
Merge pull request #146 from launchdarkly/rneal/ch101662/add-support-…
robertjneal May 11, 2021
741a076
merge from public after release
LaunchDarklyCI Jun 17, 2021
527f366
use Releaser v2 config
eli-darkly Sep 21, 2021
d2528ed
Use newer docker images (#147)
bwoskow-ld Sep 22, 2021
8852138
Merge pull request #148 from launchdarkly/eb/ch118712/releaser-v2
eli-darkly Sep 23, 2021
666e5f0
Updates docs URLs
ember-stevens Sep 24, 2021
1db3507
Merge pull request #149 from launchdarkly/emberstevens/sc-118589/url-…
ember-stevens Sep 27, 2021
3286623
Add support for 3.10 (#150)
keelerm84 Oct 6, 2021
3a64bf6
started work on FlagBuilder in as part of test data source implementa…
charukiewicz Nov 22, 2021
dd7561e
finished FlagBuilder implementation and added FlagRuleBuilder impleme…
charukiewicz Nov 23, 2021
b3bd9b4
added initial TestData interface and updated tests to not rely on tes…
charukiewicz Nov 24, 2021
bd87ace
started data source implementation
charukiewicz Nov 30, 2021
fb4aeaf
changed FlagBuilder to public class; changed FlagBuilder attributes t…
charukiewicz Nov 30, 2021
eaa8b04
Merge branch 'cc/sc-130602/test-data-flag-builder' into cc/sc-130602/…
charukiewicz Nov 30, 2021
633669a
(big segments 1) add public config/interface types
eli-darkly Nov 30, 2021
3f624ba
added implementation of test data source
charukiewicz Nov 30, 2021
4ee49e0
docstring
eli-darkly Nov 30, 2021
06a62d3
formatting
eli-darkly Nov 30, 2021
8eb95e1
ensure property doesn't return None
eli-darkly Nov 30, 2021
be01431
(big segments 2) implement evaluation, refactor eval logic & modules
eli-darkly Dec 1, 2021
7fc6fed
linting
eli-darkly Dec 1, 2021
3812412
(big segments 3) implement big segment status tracking, wire up compo…
eli-darkly Dec 2, 2021
b5d9616
typing fixes
eli-darkly Dec 2, 2021
5e75442
typing fixes
eli-darkly Dec 2, 2021
104b7ef
Merge pull request #152 from launchdarkly/eb/sc-132580/big-seg-1-types
eli-darkly Dec 2, 2021
43c01c2
Merge pull request #154 from launchdarkly/eb/sc-132580/big-seg-2-impl
eli-darkly Dec 2, 2021
7439e1f
implement SSE contract tests
eli-darkly Dec 2, 2021
e67d915
fix CI
eli-darkly Dec 2, 2021
38d15c9
fix CI again
eli-darkly Dec 2, 2021
fb93d87
fix CI
eli-darkly Dec 2, 2021
2cd71a6
disable SSE tests in Python 3.5
eli-darkly Dec 2, 2021
aa24aac
make test service port configurable
eli-darkly Dec 2, 2021
9414b33
better SSE implementation that fixes linefeed and multi-byte char issues
eli-darkly Dec 3, 2021
3588db7
fix constructor parameters in test service
eli-darkly Dec 3, 2021
8efc7bf
comment
eli-darkly Dec 3, 2021
7fdd3b3
test improvements
eli-darkly Dec 3, 2021
707fbcb
Merge pull request #155 from launchdarkly/eb/sc-132580/big-seg-3-impl
eli-darkly Dec 3, 2021
e76aef1
rm obsolete default config logic
eli-darkly Dec 3, 2021
fd1e067
Merge pull request #157 from launchdarkly/eb/sc-133195+sc-133324/bett…
eli-darkly Dec 3, 2021
7c986d6
Merge pull request #156 from launchdarkly/eb/sc-125613/sse-contract-t…
eli-darkly Dec 3, 2021
9073e54
merge from public after release
Dec 4, 2021
6657474
(big segments 4) implement big segment stores in Redis+DynamoDB, refa…
eli-darkly Dec 6, 2021
c567777
converted ldclient.integrations module from file to directory; starte…
charukiewicz Dec 6, 2021
3156801
removed setup/teardown functions leftover from test scaffold
charukiewicz Dec 6, 2021
fa7d0f5
Merge pull request #151 from launchdarkly/cc/sc-130602/test-data-flag…
charukiewicz Dec 7, 2021
8abe007
added TestData, FlagBuilder, and FlagRuleBuilder documentation; minor…
charukiewicz Dec 7, 2021
9dd064e
removed warning supression from TestData tests
charukiewicz Dec 7, 2021
86e4038
fix big segments user hash algorithm to use SHA256
eli-darkly Dec 8, 2021
7e8da3d
Merge branch 'master' into big-segments
eli-darkly Dec 8, 2021
a73c4c1
Merge branch 'big-segments' into eb/sc-132580/big-seg-sha256
eli-darkly Dec 8, 2021
9a4981e
update mypy version
eli-darkly Dec 8, 2021
4fbf338
Merge pull request #161 from launchdarkly/eb/sc-134071/mypy-version
eli-darkly Dec 8, 2021
30c3974
Merge branch 'master' into test-data
eli-darkly Dec 8, 2021
c0481f5
Merge branch 'master' into big-segments
eli-darkly Dec 8, 2021
f7d58c0
Merge branch 'big-segments' into eb/sc-132580/big-seg-sha256
eli-darkly Dec 8, 2021
8d56a51
updates to tests and related bug fixes
charukiewicz Dec 8, 2021
a16e744
Merge branch 'test-data' into cc/sc-130602/test-data-datasource
eli-darkly Dec 9, 2021
4cff3b1
Merge branch 'cc/sc-130602/test-data-datasource' into cc/sc-130602/te…
eli-darkly Dec 9, 2021
ecbe95d
always cache Big Segment query result even if it's None
eli-darkly Dec 9, 2021
489f1e7
fix test assertion
eli-darkly Dec 9, 2021
c524e7e
lint
eli-darkly Dec 9, 2021
f8e95bf
fix big segment ref format
eli-darkly Dec 9, 2021
c1d6548
fix big segments cache TTL being set to wrong value
eli-darkly Dec 9, 2021
8f9795e
Merge pull request #160 from launchdarkly/eb/sc-132580/big-seg-sha256
eli-darkly Dec 9, 2021
5f9b501
Merge pull request #162 from launchdarkly/eb/sc-132580/big-seg-cache-…
eli-darkly Dec 9, 2021
0bc07d0
Merge pull request #153 from launchdarkly/cc/sc-130602/test-data-data…
charukiewicz Dec 9, 2021
d593ade
fixed structure of fallthrough variation in result of FlagBuilder.bui…
charukiewicz Dec 9, 2021
b07015d
Merge branch 'cc/sc-130602/test-data-docs' of github.com:launchdarkly…
charukiewicz Dec 9, 2021
45f1e23
moved __test__ attribute into TestData class definition to prevent my…
charukiewicz Dec 9, 2021
5f12700
minor doc comment fix
eli-darkly Dec 10, 2021
5970c04
merge from public after release
Dec 10, 2021
ac75a6d
Merge branch 'master' of github.com:launchdarkly/python-server-sdk
eli-darkly Dec 10, 2021
f06bcae
Merge branch 'master' into test-data
eli-darkly Dec 11, 2021
b5a1342
Merge branch 'test-data' into cc/sc-130602/test-data-docs
eli-darkly Dec 11, 2021
3b1d740
Apply suggestions related to Sphinx docstring formatting from code re…
charukiewicz Dec 13, 2021
f40c7a0
Merge pull request #159 from launchdarkly/cc/sc-130602/test-data-docs
charukiewicz Dec 29, 2021
3baa843
fixed errors in the implementation of FlagBuilder's fallthrough_varia…
charukiewicz Jan 14, 2022
9d49fef
added missing value_for_all_users() method to FlagBuilder class
charukiewicz Jan 24, 2022
d235047
Fix operator parsing errors (#169)
keelerm84 Jan 27, 2022
8171136
identify should not emit event if user key is empty (#164)
keelerm84 Jan 27, 2022
5c1ce47
secondary should be treated as built-in attribute (#168)
keelerm84 Jan 27, 2022
926f94f
URIs should have trailing slashes trimmed (#165)
keelerm84 Jan 27, 2022
387d7ba
all_flags_state should always include flag version (#166)
keelerm84 Jan 27, 2022
515a05e
output event should not include a null prereqOf key (#167)
keelerm84 Jan 27, 2022
de66bc7
Merge pull request #163 from launchdarkly/cc/sc-130602/test-data-bool…
charukiewicz Feb 2, 2022
e22d5ee
Account for traffic allocation on all flags (#171)
keelerm84 Feb 3, 2022
3e1613e
Add SDK contract tests (#170)
keelerm84 Feb 3, 2022
26f7ec9
Merge branch 'master' of github.com:launchdarkly/python-server-sdk
eli-darkly Feb 14, 2022
a8b1404
Merge branch 'master' into test-data
eli-darkly Feb 14, 2022
175697b
misc fixes to test data docs + add type hints
eli-darkly Feb 14, 2022
787c715
more type hints
eli-darkly Feb 14, 2022
65e733d
remove some methods from the public test_data API
eli-darkly Feb 14, 2022
23f066c
can't use "x|y" shortcut in typehints in older Pythons; use Union
eli-darkly Feb 14, 2022
063752a
fix misc type mistakes because I forgot to run the linter
eli-darkly Feb 14, 2022
cd39e1c
Merge pull request #172 from launchdarkly/eb/sc-130602/test-data-docs…
eli-darkly Feb 14, 2022
db63930
Merge branch 'test-data' into eb/sc-130602/test-data-private-methods
eli-darkly Feb 14, 2022
3be9135
Merge pull request #173 from launchdarkly/eb/sc-130602/test-data-priv…
eli-darkly Feb 14, 2022
941b858
merge from public after release
Feb 14, 2022
4f6f6cf
update CONTRIBUTING.md and provide make targets
eli-darkly Feb 14, 2022
8ba0eeb
Merge branch 'test-data'
eli-darkly Feb 15, 2022
85bf5a2
Merge pull request #174 from launchdarkly/eb/sc-132599/coding-guidelines
eli-darkly Feb 16, 2022
394982f
merge from public after release
Feb 16, 2022
9c152c3
fixed a bug with flag rule clause builder internals; added unit test …
charukiewicz Mar 15, 2022
2d5744b
added ready argument to _TestDataSource class and indicated ready upo…
charukiewicz Mar 15, 2022
1f21ca5
Update contract tests to latest flask version (#176)
keelerm84 Mar 16, 2022
fb9494b
Merge branch 'master' into cc/sc-130602/test-data-flag-rule-builder-o…
charukiewicz Mar 16, 2022
dc35497
Merge pull request #175 from launchdarkly/cc/sc-130602/test-data-flag…
charukiewicz Mar 16, 2022
fd06213
Merge branch 'master' into private-master
keelerm84 Apr 19, 2022
58d8af7
Adds link to Relay Proxy docs
ember-stevens Apr 19, 2022
5c5a3e8
Handle explicit None values in test payload (#179)
keelerm84 Apr 20, 2022
c984111
Fix "unhandled response" error in test harness (#180)
keelerm84 Apr 20, 2022
0ce9153
Exclude booleans when getting bucketable value (#181)
keelerm84 Apr 20, 2022
ac7fa2e
merge from public after release
Apr 22, 2022
b354bb3
Merge pull request #177 from launchdarkly/emberstevens/sc-150321/stan…
ember-stevens Apr 28, 2022
443e0a6
master -> main (#182)
keelerm84 May 6, 2022
d3eb286
Loosen restriction on expiringdict (#183)
keelerm84 Jun 15, 2022
4ad2f11
Merge branch 'main' into private-main
keelerm84 Jun 15, 2022
b56b52d
merge from public after release
Jun 16, 2022
0b70f67
Fix mypy type checking (#184)
keelerm84 Jun 22, 2022
d42e600
Add support for extra Redis connection parameters (#185)
keelerm84 Jun 29, 2022
a499f2d
merge from public after release
Jul 1, 2022
707dd6f
Include wheel artifact when publishing package (#186)
keelerm84 Sep 23, 2022
1c37c15
merge from public after release
Sep 29, 2022
435e5a0
remove warn-level logging done for every Big Segments query
eli-darkly Dec 9, 2022
228123a
skip tests that use a self-signed TLS cert in Python 3.7
eli-darkly Dec 9, 2022
e265272
Merge branch 'eb/sc-180055/https-tests' into eb/sc-180058/warn-logging
eli-darkly Dec 9, 2022
09d8b96
(U2C 1) drop EOL Python versions (#189)
eli-darkly Dec 9, 2022
d068fdb
(U2C 2) remove alias event functionality (#187)
eli-darkly Dec 9, 2022
8f9c22a
(U2C 3) remove inline users in events (#188)
eli-darkly Dec 9, 2022
fb544cd
(U2C 4) remove deprecated things (#192)
eli-darkly Dec 9, 2022
6e1b477
Merge pull request #191 from launchdarkly/eb/sc-180055/https-tests
eli-darkly Dec 9, 2022
a9525e0
remove warn-level logging done for every Big Segments query (#190)
eli-darkly Dec 9, 2022
4f7f169
Merge branch 'main' into 8.0
eli-darkly Dec 9, 2022
e9daa49
implement context model
eli-darkly Dec 9, 2022
f3933c1
fix exports
eli-darkly Dec 9, 2022
ae66589
specify exports
eli-darkly Dec 9, 2022
e54e5e7
add copy constructor
eli-darkly Dec 9, 2022
3757a4a
minimal changes for SDK methods & evaluator to accept Context
eli-darkly Dec 9, 2022
f49f33c
update tests, add subscript method
eli-darkly Dec 9, 2022
980ace0
lint
eli-darkly Dec 9, 2022
cbb491c
in type hints, must use Dict[A, B] rather than dict[A, B] for Python …
eli-darkly Dec 9, 2022
67f18ae
support context kind in clauses + enable v2 contract tests
eli-darkly Dec 10, 2022
e925cdd
misc fixes
eli-darkly Dec 10, 2022
69ebd7e
Merge branch 'eb/sc-180147/context-1' into eb/sc-180147/context-2-client
eli-darkly Dec 10, 2022
0ccecc2
misc fixes
eli-darkly Dec 10, 2022
4885b18
Merge branch 'eb/sc-180147/context-2-client' into eb/sc-180187/eval-1…
eli-darkly Dec 10, 2022
16e0efd
support contextTargets
eli-darkly Dec 10, 2022
38d885e
support contextKind in rollouts/experiments
eli-darkly Dec 10, 2022
9a1f932
support includedContexts/excludedContexts in segment
eli-darkly Dec 10, 2022
213f656
comment copyedit
eli-darkly Dec 12, 2022
b07a8e4
comment fixes
eli-darkly Dec 12, 2022
51e626d
rm unused
eli-darkly Dec 12, 2022
1a6ed30
fix create_multi to support flattening
eli-darkly Dec 12, 2022
6e716c7
lint
eli-darkly Dec 12, 2022
7c2357c
Merge branch 'eb/sc-180147/context-1' into eb/sc-180147/context-2-client
eli-darkly Dec 12, 2022
e69640a
Merge pull request #194 from launchdarkly/eb/sc-180147/context-2-client
eli-darkly Dec 12, 2022
7ae9528
use custom classes for flag/segment data model
eli-darkly Dec 13, 2022
2b01775
use store adapter for safety
eli-darkly Dec 13, 2022
329e33d
misc cleanup
eli-darkly Dec 13, 2022
e0f414c
misc fixes for persistent stores
eli-darkly Dec 13, 2022
e4a478c
more database store fixes
eli-darkly Dec 13, 2022
ea414b6
Merge pull request #193 from launchdarkly/eb/sc-180147/context-1
eli-darkly Dec 13, 2022
dca671f
Merge pull request #195 from launchdarkly/eb/sc-180187/eval-1-clause
eli-darkly Dec 13, 2022
2bf0828
Merge pull request #196 from launchdarkly/eb/sc-180187/eval-2-targets
eli-darkly Dec 13, 2022
65f50c6
Merge pull request #197 from launchdarkly/eb/sc-180187/eval-3-bucketing
eli-darkly Dec 13, 2022
56d1c6f
support attribute reference lookups in evaluations
eli-darkly Dec 13, 2022
396e914
pass logger from client
eli-darkly Dec 13, 2022
364e2eb
Merge pull request #198 from launchdarkly/eb/sc-180187/eval-4-segment…
eli-darkly Dec 20, 2022
5cc102f
Merge pull request #199 from launchdarkly/eb/sc-180417/model-classes
eli-darkly Dec 20, 2022
82ffbae
Merge pull request #200 from launchdarkly/eb/sc-180187/eval-5-attr-ref
eli-darkly Dec 20, 2022
4f8b435
context kind logic for big segments + enable big segment contract tests
eli-darkly Dec 21, 2022
ed76551
formatting fixes + test cleanup
eli-darkly Dec 21, 2022
4a53780
prerequisite cycle detection
eli-darkly Dec 21, 2022
2f2363c
segment recursion
eli-darkly Dec 21, 2022
8e0108d
define custom classes for event data
eli-darkly Dec 21, 2022
b5ba0cb
add module init file
eli-darkly Dec 21, 2022
39e3ad1
linting
eli-darkly Dec 21, 2022
700e5f7
Merge pull request #201 from launchdarkly/eb/sc-180187/eval-6-big-seg…
eli-darkly Dec 21, 2022
a6b9f05
fix prereq stack logic
eli-darkly Dec 21, 2022
bce65f0
Merge pull request #202 from launchdarkly/eb/sc-180515/prereq-cycle
eli-darkly Dec 21, 2022
f808ae5
Merge pull request #203 from launchdarkly/eb/sc-180516/segment-recursion
eli-darkly Dec 21, 2022
35bd2d3
Merge pull request #204 from launchdarkly/eb/sc-181468/event-types
eli-darkly Dec 21, 2022
42af25a
(U2C 17) U2C changes for events, not including private attributes (#205)
eli-darkly Dec 21, 2022
56f4492
private attribute redaction
eli-darkly Dec 21, 2022
b7a0ba4
Merge pull request #206 from launchdarkly/eb/sc-180514/events-2-private
eli-darkly Dec 21, 2022
49cd88a
move a lot of code out of top-level modules
eli-darkly Dec 22, 2022
66afd97
TestData changes for contexts
eli-darkly Dec 23, 2022
b4044a6
Merge pull request #207 from launchdarkly/eb/sc-181476/move-impl
eli-darkly Dec 23, 2022
52297a3
Merge pull request #208 from launchdarkly/eb/sc-180517/test-data-u2c
eli-darkly Dec 23, 2022
afef6a4
general doc comment fixes for 8.0
eli-darkly Dec 23, 2022
db889df
U2C configuration updates
eli-darkly Dec 24, 2022
1804f17
Merge pull request #209 from launchdarkly/eb/sc-181675/doc-comments
eli-darkly Dec 28, 2022
37f2264
Merge pull request #210 from launchdarkly/eb/sc-181704/config-updates
eli-darkly Dec 28, 2022
a0ced67
update release metadata
eli-darkly Dec 28, 2022
404dea2
Merge branch '8.0'
eli-darkly Dec 28, 2022
0fe3f30
store flag/segment target lists as sets
eli-darkly Dec 28, 2022
62c81f4
fix type hint
eli-darkly Dec 28, 2022
bef4110
preprocess clause values for time/regex/semver operators
eli-darkly Dec 28, 2022
c8ace12
Merge pull request #211 from launchdarkly/eb/sc-181822/preprocess-tar…
eli-darkly Dec 29, 2022
48fac41
fix type checking for matches operator
eli-darkly Dec 29, 2022
f52b82c
Merge pull request #212 from launchdarkly/eb/sc-181822/preprocess-values
eli-darkly Dec 29, 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
13 changes: 5 additions & 8 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,6 @@ orbs:
workflows:
test:
jobs:
- test-linux:
name: Python 3.5
docker-image: cimg/python:3.5
skip-sse-contract-tests: true # the test service app has dependencies that aren't available in 3.5, which is EOL anyway
skip-contract-tests: true # the test service app has dependencies that aren't available in 3.5, which is EOL anyway
- test-linux:
name: Python 3.6
docker-image: cimg/python:3.6
- test-linux:
name: Python 3.7
docker-image: cimg/python:3.7
Expand All @@ -26,6 +18,9 @@ workflows:
- test-linux:
name: Python 3.10
docker-image: cimg/python:3.10
- test-linux:
name: Python 3.11
docker-image: cimg/python:3.11
- test-windows:
name: Windows Python 3
py3: true
Expand Down Expand Up @@ -57,6 +52,7 @@ jobs:
- image: consul
steps:
- checkout
- run: python --version
- run:
name: install requirements
command: |
Expand Down Expand Up @@ -142,6 +138,7 @@ jobs:
- run:
name: install Python 3
command: choco install python --no-progress
- run: python --version
- run:
name: set up DynamoDB
command: |
Expand Down
3 changes: 2 additions & 1 deletion .ldrelease/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,8 @@ publications:

branches:
- name: main
description: 7.x
description: 8.x
- name: 7.x
- name: 6.x

jobs:
Expand Down
2 changes: 1 addition & 1 deletion .readthedocs.yml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
version: 2

python:
version: 3.5
version: 3.7
install:
- requirements: docs/requirements.txt
- requirements: requirements.txt
Expand Down
8 changes: 6 additions & 2 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,10 @@ docs:

TEMP_TEST_OUTPUT=/tmp/contract-test-service.log

# TEST_HARNESS_PARAMS can be set to add -skip parameters for any contract tests that cannot yet pass
# TEST_HARNESS_PARAMS := $(TEST_HARNESS_PARAMS) \


# port 8000 and 9000 is already used in the CI environment because we're
# running a DynamoDB container and an SSE contract test
PORT=10000
Expand All @@ -33,8 +37,8 @@ start-contract-test-service-bg:
@make start-contract-test-service >$(TEMP_TEST_OUTPUT) 2>&1 &

run-contract-tests:
@curl -s https://raw.githubusercontent.com/launchdarkly/sdk-test-harness/v1.0.0/downloader/run.sh \
| VERSION=v1 PARAMS="-url http://localhost:$(PORT) -debug -stop-service-at-end $(TEST_HARNESS_PARAMS)" sh
curl -s https://raw.githubusercontent.com/launchdarkly/sdk-test-harness/v2/downloader/run.sh \
| VERSION=v2 PARAMS="-url http://localhost:$(PORT) -debug -stop-service-at-end $(TEST_HARNESS_PARAMS)" sh

contract-tests: build-contract-tests start-contract-test-service-bg run-contract-tests

Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@

## Supported Python versions

This version of the LaunchDarkly SDK is compatible with Python 3.5 through 3.10. It is tested with the most recent patch releases of those versions. Python versions 2.7 to 3.4 are no longer supported.
This version of the LaunchDarkly SDK is compatible with Python 3.7 through 3.11. It is tested with the most recent patch releases of those versions. Python versions 2.7 to 3.6 are no longer supported.

## Getting started

Expand Down
37 changes: 37 additions & 0 deletions contract-tests/big_segment_store_fixture.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
import json
import os
import sys
from typing import Optional
import urllib3

# Import ldclient from parent directory
sys.path.insert(1, os.path.join(sys.path[0], '..'))
from ldclient.interfaces import BigSegmentStore, BigSegmentStoreMetadata


http = urllib3.PoolManager()


class BigSegmentStoreFixture(BigSegmentStore):
def __init__(self, callback_uri: str):
self._callback_uri = callback_uri

def get_metadata(self) -> BigSegmentStoreMetadata:
resp_data = self._post_callback('/getMetadata', None)
return BigSegmentStoreMetadata(resp_data.get("lastUpToDate"))

def get_membership(self, context_hash: str) -> Optional[dict]:
resp_data = self._post_callback('/getMembership', {'contextHash': context_hash})
return resp_data.get("values")

def _post_callback(self, path: str, params: Optional[dict]) -> dict:
url = self._callback_uri + path
resp = http.request('POST', url,
body=None if params is None else json.dumps(params),
headers=None if params is None else {'Content-Type': 'application/json'})
if resp.status != 200:
raise Exception("HTTP error %d from callback to %s" % (resp.status, url))
return json.loads(resp.data.decode('utf-8'))

def stop(self):
pass
99 changes: 81 additions & 18 deletions contract-tests/client_entity.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,12 @@
import json
import logging
import os
import sys
from typing import Optional

from big_segment_store_fixture import BigSegmentStoreFixture

from ldclient.config import BigSegmentsConfig

# Import ldclient from parent directory
sys.path.insert(1, os.path.join(sys.path[0], '..'))
Expand All @@ -16,8 +22,7 @@ def __init__(self, tag, config):
streaming = config["streaming"]
if streaming.get("baseUri") is not None:
opts["stream_uri"] = streaming["baseUri"]
if streaming.get("initialRetryDelayMs") is not None:
opts["initial_reconnect_delay"] = streaming["initialRetryDelayMs"] / 1000.0
_set_optional_time_prop(streaming, "initialRetryDelayMs", opts, "initial_reconnect_delay")

if config.get("events") is not None:
events = config["events"]
Expand All @@ -28,13 +33,22 @@ def __init__(self, tag, config):
opts["diagnostic_opt_out"] = not events.get("enableDiagnostics", False)
opts["all_attributes_private"] = events.get("allAttributesPrivate", False)
opts["private_attribute_names"] = events.get("globalPrivateAttributes", {})
if events.get("flushIntervalMs") is not None:
opts["flush_interval"] = events["flushIntervalMs"] / 1000.0
if events.get("inlineUsers") is not None:
opts["inline_users_in_events"] = events["inlineUsers"]
_set_optional_time_prop(events, "flushIntervalMs", opts, "flush_interval")
else:
opts["send_events"] = False

if config.get("bigSegments") is not None:
big_params = config["bigSegments"]
big_config = {
"store": BigSegmentStoreFixture(big_params["callbackUri"])
}
if big_params.get("userCacheSize") is not None:
big_config["context_cache_size"] = big_params["userCacheSize"]
_set_optional_time_prop(big_params, "userCacheTimeMs", big_config, "context_cache_time")
_set_optional_time_prop(big_params, "statusPollIntervalMs", big_config, "status_poll_interval")
_set_optional_time_prop(big_params, "staleAfterMs", big_config, "stale_after")
opts["big_segments"] = BigSegmentsConfig(**big_config)

start_wait = config.get("startWaitTimeMs") or 5000
config = Config(**opts)

Expand All @@ -43,41 +57,90 @@ def __init__(self, tag, config):
def is_initializing(self) -> bool:
return self.client.is_initialized()

def evaluate(self, params) -> dict:
def evaluate(self, params: dict) -> dict:
response = {}

if params.get("detail", False):
detail = self.client.variation_detail(params["flagKey"], params["user"], params["defaultValue"])
detail = self.client.variation_detail(params["flagKey"], params["context"], params["defaultValue"])
response["value"] = detail.value
response["variationIndex"] = detail.variation_index
response["reason"] = detail.reason
else:
response["value"] = self.client.variation(params["flagKey"], params["user"], params["defaultValue"])
response["value"] = self.client.variation(params["flagKey"], params["context"], params["defaultValue"])

return response

def evaluate_all(self, params):
def evaluate_all(self, params: dict):
opts = {}
opts["client_side_only"] = params.get("clientSideOnly", False)
opts["with_reasons"] = params.get("withReasons", False)
opts["details_only_for_tracked_flags"] = params.get("detailsOnlyForTrackedFlags", False)

state = self.client.all_flags_state(params["user"], **opts)
state = self.client.all_flags_state(params["context"], **opts)

return {"state": state.to_json_dict()}

def track(self, params):
self.client.track(params["eventKey"], params["user"], params["data"], params.get("metricValue", None))

def identify(self, params):
self.client.identify(params["user"])
def track(self, params: dict):
self.client.track(params["eventKey"], params["context"], params["data"], params.get("metricValue", None))

def alias(self, params):
self.client.alias(params["user"], params["previousUser"])
def identify(self, params: dict):
self.client.identify(params["context"])

def flush(self):
self.client.flush()

def secure_mode_hash(self, params: dict) -> dict:
return {"result": self.client.secure_mode_hash(params["context"])}

def context_build(self, params: dict) -> dict:
if params.get("multi"):
b = Context.multi_builder()
for c in params.get("multi"):
b.add(self._context_build_single(c))
return self._context_response(b.build())
return self._context_response(self._context_build_single(params["single"]))

def _context_build_single(self, params: dict) -> Context:
b = Context.builder(params["key"])
if "kind" in params:
b.kind(params["kind"])
if "name" in params:
b.name(params["name"])
if "anonymous" in params:
b.anonymous(params["anonymous"])
if "custom" in params:
for k, v in params.get("custom").items():
b.set(k, v)
if "private" in params:
for attr in params.get("private"):
b.private(attr)
return b.build()

def context_convert(self, params: dict) -> dict:
input = params["input"]
try:
props = json.loads(input)
return self._context_response(Context.from_dict(props))
except Exception as e:
return {"error": str(e)}

def _context_response(self, c: Context) -> dict:
if c.valid:
return {"output": c.to_json_string()}
return {"error": c.error}

def get_big_segment_store_status(self) -> dict:
status = self.client.big_segment_store_status_provider.status
return {
"available": status.available,
"stale": status.stale
}

def close(self):
self.client.close()
self.log.info('Test ended')

def _set_optional_time_prop(params_in: dict, name_in: str, params_out: dict, name_out: str):
if params_in.get(name_in) is not None:
params_out[name_out] = params_in[name_in] / 1000.0
return None
57 changes: 35 additions & 22 deletions contract-tests/service.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@

default_port = 8000


# logging configuration
dictConfig({
'version': 1,
Expand All @@ -30,11 +31,10 @@
'level': 'INFO',
'handlers': ['console']
},
'ldclient.util': {
'level': 'INFO',
'handlers': ['console']
},
'loggers': {
'ldclient': {
'level': 'INFO', # change to 'DEBUG' to enable SDK debug logging
},
'werkzeug': { 'level': 'ERROR' } # disable irrelevant Flask app logging
}
})
Expand All @@ -53,6 +53,7 @@ def handle_exception(e):
if isinstance(e, HTTPException):
return e

app.logger.exception(e)
return str(e), 500

@app.route('/', methods=['GET'])
Expand All @@ -63,6 +64,9 @@ def status():
'all-flags-with-reasons',
'all-flags-client-side-only',
'all-flags-details-only-for-tracked-flags',
'big-segments',
'context-type',
'secure-mode-hash',
]
}
return (json.dumps(body), 200, {'Content-type': 'application/json'})
Expand Down Expand Up @@ -102,26 +106,35 @@ def post_client_command(id):
if client is None:
return ('', 404)

if params.get('command') == "evaluate":
response = client.evaluate(params.get("evaluate"))
return (json.dumps(response), 200)
elif params.get("command") == "evaluateAll":
response = client.evaluate_all(params.get("evaluateAll"))
return (json.dumps(response), 200)
elif params.get("command") == "customEvent":
client.track(params.get("customEvent"))
return ('', 201)
elif params.get("command") == "identifyEvent":
client.identify(params.get("identifyEvent"))
return ('', 201)
elif params.get("command") == "aliasEvent":
client.alias(params.get("aliasEvent"))
return ('', 201)
elif params.get('command') == "flushEvents":
command = params.get('command')
sub_params = params.get(command)

response = None

if command == "evaluate":
response = client.evaluate(sub_params)
elif command == "evaluateAll":
response = client.evaluate_all(sub_params)
elif command == "customEvent":
client.track(sub_params)
elif command == "identifyEvent":
client.identify(sub_params)
elif command == "flushEvents":
client.flush()
elif command == "secureModeHash":
response = client.secure_mode_hash(sub_params)
elif command == "contextBuild":
response = client.context_build(sub_params)
elif command == "contextConvert":
response = client.context_convert(sub_params)
elif command == "getBigSegmentStoreStatus":
response = client.get_big_segment_store_status()
else:
return ('', 400)

if response is None:
return ('', 201)

return ('', 400)
return (json.dumps(response), 200)

@app.route('/clients/<id>', methods=['DELETE'])
def delete_client(id):
Expand Down
12 changes: 0 additions & 12 deletions docs/api-deprecated.rst

This file was deleted.

Loading