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

chore(tests): sync client verification tests #1046

Merged
merged 419 commits into from
Dec 18, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
419 commits
Select commit Hold shift + click to select a range
eb5cd48
refactor outputs
daniel-sanche Jul 12, 2024
e5a8792
renamed artifact class; added comments
daniel-sanche Jul 12, 2024
39ae907
added back conversion annotations
daniel-sanche Jul 12, 2024
d17a98c
Merge branch 'cross_sync_pr1_replacements' into cross_sync_pr2_genera…
daniel-sanche Jul 12, 2024
fd1fb71
fixed decorator sync_impl call
daniel-sanche Jul 12, 2024
c0b4185
Merge branch 'cross_sync_pr1_replacements' into cross_sync_pr2_genera…
daniel-sanche Jul 12, 2024
adb092e
use add_mapping in place of replace_symbols
daniel-sanche Jul 12, 2024
45efa16
support automatic attribute registration
daniel-sanche Jul 12, 2024
e1ec974
reduced replace_symbols usage in tests
daniel-sanche Jul 13, 2024
021fde2
fixed lint issues
daniel-sanche Jul 13, 2024
58405d1
Merge branch 'cross_sync_pr1_replacements' into cross_sync_pr2_genera…
daniel-sanche Jul 13, 2024
de0fd90
added missing imports
daniel-sanche Jul 13, 2024
6ca3ddd
get mappings working for sync implementation
daniel-sanche Jul 13, 2024
b2cf937
moved decorators into new file
daniel-sanche Jul 15, 2024
4860061
moved transformation from transformers into decorators
daniel-sanche Jul 16, 2024
63891d7
simplified arguments for decorators
daniel-sanche Jul 16, 2024
164f5a8
use separate decorate method
daniel-sanche Jul 16, 2024
8317973
comments and clean up
daniel-sanche Jul 17, 2024
f9dd41d
ran blacken
daniel-sanche Jul 17, 2024
22b093f
moved ast decorators into new file
daniel-sanche Jul 17, 2024
5ebf889
Merge branch 'cross_sync_pr1_replacements' into cross_sync_pr2_genera…
daniel-sanche Jul 17, 2024
8d13c5e
ran blacken
daniel-sanche Jul 17, 2024
ea8072f
Merge branch 'cross_sync_pr1_replacements' into cross_sync_pr2_genera…
daniel-sanche Jul 17, 2024
769cac1
changed sync impl name
daniel-sanche Jul 17, 2024
f87b832
fixed mapping function
daniel-sanche Jul 17, 2024
f2b6d08
convert to async with pytest mark
daniel-sanche Jul 17, 2024
754adf8
Merge branch 'cross_sync_pr1_replacements' into cross_sync_pr2_genera…
daniel-sanche Jul 17, 2024
3ed5935
convert changes async to sync def by default
daniel-sanche Jul 17, 2024
d0ba7b0
added rm_aio for stripping asyncio keywords
daniel-sanche Jul 18, 2024
37b4833
reverted client and test changes
daniel-sanche Jul 18, 2024
af020a2
Revert "reverted client and test changes"
daniel-sanche Jul 18, 2024
698902d
added sync pooled transport
daniel-sanche Jul 18, 2024
64166db
only strip CrossSync.rm_aio on Call visits
daniel-sanche Jul 18, 2024
73ba23b
support decorators in nested functions
daniel-sanche Jul 18, 2024
12e8860
added missing convert annotations
daniel-sanche Jul 22, 2024
63a528a
added import blocks for sync versions
daniel-sanche Jul 22, 2024
f5dcdf5
added annotations to tests
daniel-sanche Jul 22, 2024
be40771
removed unneeded test imports
daniel-sanche Jul 22, 2024
a676d49
ran blacken
daniel-sanche Jul 22, 2024
c63d88e
fixed lint issues
daniel-sanche Jul 22, 2024
5d11fc0
added generated files
daniel-sanche Jul 22, 2024
3bb6c6f
added files to __init__.py
daniel-sanche Jul 22, 2024
4a041c8
added cross_sync to path for transformers
daniel-sanche Jul 22, 2024
cbc36dd
support table in helpers
daniel-sanche Jul 22, 2024
03b60ed
removed quoted cross sync classes
daniel-sanche Jul 22, 2024
3762a03
fixed mypy issues
daniel-sanche Jul 22, 2024
274bd36
moved cross_sync into own directory
daniel-sanche Jul 22, 2024
5611614
added docstrings
daniel-sanche Jul 22, 2024
ad95748
added README
daniel-sanche Jul 22, 2024
cad416d
fixed README formatting
daniel-sanche Jul 22, 2024
9b92e65
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Jul 22, 2024
18292a4
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Jul 22, 2024
9a19658
added rm_aio to pytest and convert decorators
daniel-sanche Jul 23, 2024
a378c45
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Jul 23, 2024
02b2268
Merge branch 'main' into cross_sync2_pr1_architecture
daniel-sanche Jul 23, 2024
f3643f1
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Jul 23, 2024
dc54f7a
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Jul 23, 2024
b64c0c7
create paths when writing sync outputs
daniel-sanche Jul 23, 2024
223f337
moved files
daniel-sanche Jul 23, 2024
51d2358
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Jul 23, 2024
2a87b83
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Jul 23, 2024
3600a63
moved add_mapping into metaclass
daniel-sanche Jul 24, 2024
295f3a2
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Jul 24, 2024
6ce1b5c
fixed mypy issues
daniel-sanche Jul 24, 2024
6ac4c71
ignore unneeded mypy check
daniel-sanche Jul 24, 2024
d76cb5c
add mappings in __init__.py
daniel-sanche Jul 25, 2024
a36f89d
Merge branch 'main' into cross_sync2_pr1_architecture
daniel-sanche Aug 9, 2024
ceabe03
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Aug 13, 2024
56cdbc1
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Aug 13, 2024
449bb39
changed mapping method
daniel-sanche Aug 13, 2024
e5d6a29
added annotations for execute_query
daniel-sanche Aug 13, 2024
ebf126a
replace all instances in docstrings
daniel-sanche Aug 13, 2024
3d8c79b
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Aug 13, 2024
98d1fd9
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Aug 13, 2024
2c926df
regenerated files
daniel-sanche Aug 13, 2024
792abd9
added next to cross_sync
daniel-sanche Aug 30, 2024
1006496
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Aug 30, 2024
5dc231c
moved execute_query e2e tests from system to unit
daniel-sanche Aug 30, 2024
f73498c
ran blacken
daniel-sanche Aug 30, 2024
6ecbf72
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Aug 30, 2024
d884e5b
added execute_query tests
daniel-sanche Aug 30, 2024
18854f0
added docstring templating
daniel-sanche Sep 3, 2024
97d63e0
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Sep 3, 2024
5396bc4
use templating in docstrings
daniel-sanche Sep 3, 2024
86cb80f
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 3, 2024
1433136
regenerated files
daniel-sanche Sep 3, 2024
2dce3b9
added test file for cross sync
daniel-sanche Sep 3, 2024
ade18b1
added some tests
daniel-sanche Sep 4, 2024
933a626
moved wait into aliases
daniel-sanche Sep 5, 2024
8efe71d
stripped out condition_wait
daniel-sanche Sep 5, 2024
09623f4
added tests for event_wait
daniel-sanche Sep 5, 2024
6fcbc89
added tests for create_task
daniel-sanche Sep 5, 2024
9044c4a
added tests for remaining functions
daniel-sanche Sep 5, 2024
ee11e04
added test outline for decorators
daniel-sanche Sep 5, 2024
89c2abe
added tests for ExportSync
daniel-sanche Sep 5, 2024
7925b24
added tests for convert
daniel-sanche Sep 5, 2024
de32f7f
added remaining decorator tests
daniel-sanche Sep 5, 2024
3c0f1de
added mapping tests
daniel-sanche Sep 5, 2024
da38ac4
added e2e test structure for cross_sync
daniel-sanche Sep 5, 2024
169255b
fixed failing nox tests
daniel-sanche Sep 5, 2024
5eddd03
added test cases
daniel-sanche Sep 5, 2024
c616143
added tests
daniel-sanche Sep 5, 2024
042f89b
added cross_sync_methods e2e test cases
daniel-sanche Sep 6, 2024
f186d6b
added tests for class generation
daniel-sanche Sep 6, 2024
7a0c638
moved cross_sync tests into system tests
daniel-sanche Sep 6, 2024
a3cb9a6
fixed lint issues
daniel-sanche Sep 6, 2024
0c91eb7
fixed mypy
daniel-sanche Sep 6, 2024
5484f5e
changed system_emulated version
daniel-sanche Sep 6, 2024
e7881da
fixed system test version format
daniel-sanche Sep 6, 2024
bc67b30
fixed unit-3.7 issues
daniel-sanche Sep 6, 2024
11ab1d0
fixed lint
daniel-sanche Sep 6, 2024
bb9c160
added mutations batcher tests
daniel-sanche Sep 9, 2024
06e0425
batcher uses multuple sync executors
daniel-sanche Sep 9, 2024
288c645
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Sep 9, 2024
13abfd4
implemented wait manually
daniel-sanche Sep 9, 2024
93acd0d
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Sep 9, 2024
49d5036
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 9, 2024
6ceb913
regenerated files
daniel-sanche Sep 9, 2024
1318ab6
fixed order of executor close
daniel-sanche Sep 10, 2024
a38b985
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 10, 2024
fd4b779
updated generated code
daniel-sanche Sep 10, 2024
8d15f48
changed num workers
daniel-sanche Sep 10, 2024
8bdddf4
added noxfile step to generate sync
daniel-sanche Sep 10, 2024
bb2a539
added test for generated code
daniel-sanche Sep 10, 2024
78c1405
added missing unit test deps
daniel-sanche Sep 10, 2024
b4608cb
run generate_sync from owlbot
daniel-sanche Sep 10, 2024
7dc9a2b
simplified file processing
daniel-sanche Sep 11, 2024
aacd8aa
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Sep 11, 2024
18484a2
updated CrossSync.export statements
daniel-sanche Sep 11, 2024
93aac2a
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 11, 2024
41576f7
fixed issues in generation
daniel-sanche Sep 11, 2024
7d5df6d
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Sep 11, 2024
0b9f377
fixed lint
daniel-sanche Sep 11, 2024
34833ef
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 11, 2024
8b13583
regenerated files
daniel-sanche Sep 11, 2024
7eb6ac4
use consistent black version
daniel-sanche Sep 11, 2024
0efb7f6
🦉 Updates from OwlBot post-processor
gcf-owl-bot[bot] Sep 11, 2024
d4224cc
changed black version
daniel-sanche Sep 11, 2024
c8d91c0
fixed underscores in annotations
daniel-sanche Sep 11, 2024
ef00397
fixed string access
daniel-sanche Sep 11, 2024
ea571bd
simplified transformers. Removed CrossSyncMethodHandler
daniel-sanche Sep 12, 2024
e42655b
simplified Convert decorator
daniel-sanche Sep 12, 2024
e972385
fixed 3.7 tests
daniel-sanche Sep 12, 2024
81a06f8
fixed mypy issues
daniel-sanche Sep 12, 2024
db8c156
extract header from code
daniel-sanche Sep 12, 2024
c418af2
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Sep 12, 2024
d0dcbff
fix mock import
daniel-sanche Sep 12, 2024
b382993
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 12, 2024
22d3e40
fix test_sync_up_to_date test
daniel-sanche Sep 12, 2024
c16ea30
fix annotations
daniel-sanche Sep 12, 2024
37c3226
add warning to generated header
daniel-sanche Sep 13, 2024
54ee3be
updated README
daniel-sanche Sep 13, 2024
d44b829
made drop_method into drop, with support for classes
daniel-sanche Sep 13, 2024
61490e5
renamed export into convert_class
daniel-sanche Sep 13, 2024
ea0d5c4
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Sep 13, 2024
b8b2181
use new decorator names
daniel-sanche Sep 13, 2024
74368a2
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 13, 2024
c6fcd69
regenerate files
daniel-sanche Sep 13, 2024
5e30192
removed unused annotation
daniel-sanche Sep 13, 2024
26315e4
ran blacken
daniel-sanche Sep 13, 2024
a45a6f6
extracted branch trimming into own transformer
daniel-sanche Sep 13, 2024
7052b31
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Sep 13, 2024
be9c50d
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 13, 2024
dd2a65f
fixed visit to generic visit
daniel-sanche Sep 13, 2024
0d487eb
import ExecuteQueryIterator
daniel-sanche Sep 17, 2024
a4a591b
added docs for sync files
daniel-sanche Sep 17, 2024
5736661
add execute query iterators to cross sync mappings
daniel-sanche Sep 17, 2024
afe25fe
regenerated sync
daniel-sanche Sep 17, 2024
59a5df2
update transformer value access
daniel-sanche Sep 17, 2024
85f2bfd
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Sep 17, 2024
1dc12c8
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 17, 2024
62d46ec
fixed py37 test
daniel-sanche Sep 17, 2024
087167f
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 17, 2024
c3675ce
regenerate files
daniel-sanche Sep 17, 2024
7dc78e1
fixed docfx
daniel-sanche Sep 17, 2024
9725131
increase max depth
daniel-sanche Sep 17, 2024
5a0fbba
put sync on top
daniel-sanche Sep 17, 2024
fd765a7
added notes to README
daniel-sanche Sep 17, 2024
487f8b2
generate into _sync_autogen directories
daniel-sanche Sep 17, 2024
77560c9
moved cross_sync directory
daniel-sanche Sep 18, 2024
252ddef
fixed outdated name
daniel-sanche Sep 18, 2024
f34d9a2
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Sep 18, 2024
3c806b5
fixed import path
daniel-sanche Sep 18, 2024
8818628
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 18, 2024
fff417c
fixed import
daniel-sanche Sep 18, 2024
c346c56
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 18, 2024
e894845
moved files to _sync_autogen
daniel-sanche Sep 18, 2024
ab6fa6d
regenerated files
daniel-sanche Sep 18, 2024
6e71ec9
fixed imports
daniel-sanche Sep 18, 2024
720cf81
fixed import
daniel-sanche Sep 18, 2024
c82d967
moved tests
daniel-sanche Sep 18, 2024
48d44a6
renamed test file
daniel-sanche Sep 18, 2024
7c52d54
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Sep 18, 2024
ea281a6
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 18, 2024
7f07436
rm_aio in decorator for async
daniel-sanche Sep 27, 2024
e4b2e9b
remove owlbot generation
daniel-sanche Sep 27, 2024
c2c28e6
improved error message
daniel-sanche Sep 27, 2024
dba89e6
added sanity check to sync_up_to_date
daniel-sanche Sep 27, 2024
8cc4e07
use cross_sync for test proxy
daniel-sanche Sep 27, 2024
3c175ae
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 27, 2024
a8f371c
updated conformance tests for sync client
daniel-sanche Sep 27, 2024
20bb81d
fixed test proxy issues
daniel-sanche Sep 27, 2024
c75df5d
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Sep 27, 2024
61e3339
updated test proxy files
daniel-sanche Sep 27, 2024
601edf7
skip multistream conformance tests in sync surface
daniel-sanche Sep 27, 2024
86651db
add skips into github actions file
daniel-sanche Sep 27, 2024
2ab2e40
fixed typo
daniel-sanche Sep 27, 2024
14a5f25
renamed with_formatter
daniel-sanche Oct 24, 2024
8830375
fixed docstrings
daniel-sanche Oct 24, 2024
6be8180
cleaning up rm_aio
daniel-sanche Oct 24, 2024
54e3007
accept None as empty string
daniel-sanche Oct 24, 2024
5811a98
use None for empty string
daniel-sanche Oct 24, 2024
480b139
🦉 Updates from OwlBot post-processor
gcf-owl-bot[bot] Oct 24, 2024
66fc807
move _MB_SIZE back to batcher
daniel-sanche Oct 24, 2024
8b3b9c9
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Oct 24, 2024
89a816a
removed rm_aio call annotations
daniel-sanche Oct 25, 2024
c6f053b
fixed broken imports
daniel-sanche Oct 25, 2024
bee3e84
rm_aio at function level by default
daniel-sanche Oct 25, 2024
36c78ba
render to disk by default
daniel-sanche Oct 25, 2024
3c44095
fixed lint
daniel-sanche Oct 25, 2024
9244f56
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Oct 25, 2024
6135ccc
fixed mypy issue
daniel-sanche Oct 25, 2024
ff9d019
fixed unit tests
daniel-sanche Oct 25, 2024
56c76ef
Merge branch 'cross_sync2_pr1_architecture' into cross_sync2_pr2_anno…
daniel-sanche Oct 31, 2024
8a2f3ed
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Oct 31, 2024
26eeb0c
regnerated sync files
daniel-sanche Oct 31, 2024
ae5dc6a
Merge branch 'main' into cross_sync2_pr2_annotations
daniel-sanche Nov 8, 2024
c95ca68
addressing broken tests
daniel-sanche Nov 8, 2024
4951b0f
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Nov 11, 2024
e7ce0d0
regenerated files
daniel-sanche Nov 11, 2024
7a1e422
removed unneeded import
daniel-sanche Nov 11, 2024
008e724
fix tests
daniel-sanche Nov 11, 2024
6945a48
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Nov 11, 2024
2d04db7
fixed formatter param
daniel-sanche Nov 11, 2024
7fb2134
fixed grace_period for sync client
daniel-sanche Nov 11, 2024
e8d122e
fixed lint
daniel-sanche Nov 11, 2024
d489ad3
cleaned up imports
daniel-sanche Nov 12, 2024
e0ab0b7
Merge branch 'cross_sync2_pr2_annotations' into cross_sync2_pr3_gener…
daniel-sanche Nov 12, 2024
0d7d7ea
fixed lint
daniel-sanche Nov 12, 2024
49c7059
Merge branch 'main' into cross_sync2_pr3_generated_sync
daniel-sanche Nov 28, 2024
081a234
updated sync code
daniel-sanche Nov 28, 2024
d0768d3
fix docs issue
daniel-sanche Nov 28, 2024
61707ca
remove new tests from this PR
daniel-sanche Nov 28, 2024
b245b78
removed missing lines
daniel-sanche Nov 28, 2024
47921f3
Revert "removed missing lines"
daniel-sanche Nov 28, 2024
dfb3dc1
Revert "remove new tests from this PR"
daniel-sanche Nov 28, 2024
34fb34c
Merge branch 'main' into cross_sync2_pr4_tests
daniel-sanche Dec 12, 2024
6a456c1
removed duplicate files
daniel-sanche Dec 12, 2024
dbe86f1
regenerated files
daniel-sanche Dec 12, 2024
710190b
fix typo
daniel-sanche Dec 17, 2024
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 .cross_sync/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,8 @@ Generation can be initiated using `nox -s generate_sync`
from the root of the project. This will find all classes with the `__CROSS_SYNC_OUTPUT__ = "path/to/output"`
annotation, and generate a sync version of classes marked with `@CrossSync.convert_sync` at the output path.

There is a unit test at `tests/unit/data/test_sync_up_to_date.py` that verifies that the generated code is up to date

## Architecture

CrossSync is made up of two parts:
Expand Down
12 changes: 11 additions & 1 deletion .github/workflows/conformance.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,15 @@ jobs:
matrix:
test-version: [ "v0.0.2" ]
py-version: [ 3.8 ]
client-type: [ "async", "legacy" ]
client-type: [ "async", "sync", "legacy" ]
include:
- client-type: "sync"
# sync client does not support concurrent streams
test_args: "-skip _Generic_MultiStream"
- client-type: "legacy"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Im wondering if we could remove this

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah for sure, I opened #1054 to track this

# legacy client is synchronous and does not support concurrent streams
# legacy client does not expose mutate_row. Disable those tests
test_args: "-skip _Generic_MultiStream -skip TestMutateRow_"
fail-fast: false
name: "${{ matrix.client-type }} client / python ${{ matrix.py-version }} / test tag ${{ matrix.test-version }}"
steps:
Expand All @@ -53,4 +61,6 @@ jobs:
env:
CLIENT_TYPE: ${{ matrix.client-type }}
PYTHONUNBUFFERED: 1
TEST_ARGS: ${{ matrix.test_args }}
PROXY_PORT: 9999

10 changes: 1 addition & 9 deletions .kokoro/conformance.sh
Original file line number Diff line number Diff line change
Expand Up @@ -19,16 +19,7 @@ set -eo pipefail
## cd to the parent directory, i.e. the root of the git repo
cd $(dirname $0)/..

PROXY_ARGS=""
TEST_ARGS=""
if [[ "${CLIENT_TYPE^^}" == "LEGACY" ]]; then
echo "Using legacy client"
# legacy client does not expose mutate_row. Disable those tests
TEST_ARGS="-skip TestMutateRow_"
fi

# Build and start the proxy in a separate process
PROXY_PORT=9999
pushd test_proxy
nohup python test_proxy.py --port $PROXY_PORT --client_type=$CLIENT_TYPE &
proxyPID=$!
Expand All @@ -42,6 +33,7 @@ function cleanup() {
trap cleanup EXIT

# Run the conformance test
echo "running tests with args: $TEST_ARGS"
pushd cloud-bigtable-clients-test/tests
eval "go test -v -proxy_addr=:$PROXY_PORT $TEST_ARGS"
RETURN_CODE=$?
Expand Down
2 changes: 1 addition & 1 deletion noxfile.py
Original file line number Diff line number Diff line change
Expand Up @@ -298,7 +298,7 @@ def system_emulated(session):


@nox.session(python=SYSTEM_TEST_PYTHON_VERSIONS)
@nox.parametrize("client_type", ["async"])
@nox.parametrize("client_type", ["async", "sync", "legacy"])
def conformance(session, client_type):
# install dependencies
constraints_path = str(
Expand Down
2 changes: 1 addition & 1 deletion test_proxy/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ python test_proxy.py --port 8080
```

By default, the test_proxy targets the async client. You can change this by passing in the `--client_type` flag.
Valid options are `async` and `legacy`.
Valid options are `async`, `sync`, and `legacy`.

```
python test_proxy.py --client_type=legacy
Expand Down
185 changes: 185 additions & 0 deletions test_proxy/handlers/client_handler_data_sync_autogen.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,185 @@
# Copyright 2024 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

# This file is automatically generated by CrossSync. Do not edit manually.

"""
This module contains the client handler process for proxy_server.py.
"""
import os
from google.cloud.environment_vars import BIGTABLE_EMULATOR
from google.cloud.bigtable.data._cross_sync import CrossSync
from client_handler_data_async import error_safe


class TestProxyClientHandler:
"""
Implements the same methods as the grpc server, but handles the client
library side of the request.

Requests received in TestProxyGrpcServer are converted to a dictionary,
and supplied to the TestProxyClientHandler methods as kwargs.
The client response is then returned back to the TestProxyGrpcServer
"""

def __init__(
self,
data_target=None,
project_id=None,
instance_id=None,
app_profile_id=None,
per_operation_timeout=None,
**kwargs
):
self.closed = False
os.environ[BIGTABLE_EMULATOR] = data_target
self.client = CrossSync._Sync_Impl.DataClient(project=project_id)
self.instance_id = instance_id
self.app_profile_id = app_profile_id
self.per_operation_timeout = per_operation_timeout

def close(self):
self.closed = True

@error_safe
async def ReadRows(self, request, **kwargs):
table_id = request.pop("table_name").split("/")[-1]
app_profile_id = self.app_profile_id or request.get("app_profile_id", None)
table = self.client.get_table(self.instance_id, table_id, app_profile_id)
kwargs["operation_timeout"] = (
kwargs.get("operation_timeout", self.per_operation_timeout) or 20
)
result_list = table.read_rows(request, **kwargs)
serialized_response = [row._to_dict() for row in result_list]
return serialized_response

@error_safe
async def ReadRow(self, row_key, **kwargs):
table_id = kwargs.pop("table_name").split("/")[-1]
app_profile_id = self.app_profile_id or kwargs.get("app_profile_id", None)
table = self.client.get_table(self.instance_id, table_id, app_profile_id)
kwargs["operation_timeout"] = (
kwargs.get("operation_timeout", self.per_operation_timeout) or 20
)
result_row = table.read_row(row_key, **kwargs)
if result_row:
return result_row._to_dict()
else:
return "None"

@error_safe
async def MutateRow(self, request, **kwargs):
from google.cloud.bigtable.data.mutations import Mutation

table_id = request["table_name"].split("/")[-1]
app_profile_id = self.app_profile_id or request.get("app_profile_id", None)
table = self.client.get_table(self.instance_id, table_id, app_profile_id)
kwargs["operation_timeout"] = (
kwargs.get("operation_timeout", self.per_operation_timeout) or 20
)
row_key = request["row_key"]
mutations = [Mutation._from_dict(d) for d in request["mutations"]]
table.mutate_row(row_key, mutations, **kwargs)
return "OK"

@error_safe
async def BulkMutateRows(self, request, **kwargs):
from google.cloud.bigtable.data.mutations import RowMutationEntry

table_id = request["table_name"].split("/")[-1]
app_profile_id = self.app_profile_id or request.get("app_profile_id", None)
table = self.client.get_table(self.instance_id, table_id, app_profile_id)
kwargs["operation_timeout"] = (
kwargs.get("operation_timeout", self.per_operation_timeout) or 20
)
entry_list = [
RowMutationEntry._from_dict(entry) for entry in request["entries"]
]
table.bulk_mutate_rows(entry_list, **kwargs)
return "OK"

@error_safe
async def CheckAndMutateRow(self, request, **kwargs):
from google.cloud.bigtable.data.mutations import Mutation, SetCell

table_id = request["table_name"].split("/")[-1]
app_profile_id = self.app_profile_id or request.get("app_profile_id", None)
table = self.client.get_table(self.instance_id, table_id, app_profile_id)
kwargs["operation_timeout"] = (
kwargs.get("operation_timeout", self.per_operation_timeout) or 20
)
row_key = request["row_key"]
true_mutations = []
for mut_dict in request.get("true_mutations", []):
try:
true_mutations.append(Mutation._from_dict(mut_dict))
except ValueError:
mutation = SetCell("", "", "", 0)
true_mutations.append(mutation)
false_mutations = []
for mut_dict in request.get("false_mutations", []):
try:
false_mutations.append(Mutation._from_dict(mut_dict))
except ValueError:
false_mutations.append(SetCell("", "", "", 0))
predicate_filter = request.get("predicate_filter", None)
result = table.check_and_mutate_row(
row_key,
predicate_filter,
true_case_mutations=true_mutations,
false_case_mutations=false_mutations,
**kwargs
)
return result

@error_safe
async def ReadModifyWriteRow(self, request, **kwargs):
from google.cloud.bigtable.data.read_modify_write_rules import IncrementRule
from google.cloud.bigtable.data.read_modify_write_rules import AppendValueRule

table_id = request["table_name"].split("/")[-1]
app_profile_id = self.app_profile_id or request.get("app_profile_id", None)
table = self.client.get_table(self.instance_id, table_id, app_profile_id)
kwargs["operation_timeout"] = (
kwargs.get("operation_timeout", self.per_operation_timeout) or 20
)
row_key = request["row_key"]
rules = []
for rule_dict in request.get("rules", []):
qualifier = rule_dict["column_qualifier"]
if "append_value" in rule_dict:
new_rule = AppendValueRule(
rule_dict["family_name"], qualifier, rule_dict["append_value"]
)
else:
new_rule = IncrementRule(
rule_dict["family_name"], qualifier, rule_dict["increment_amount"]
)
rules.append(new_rule)
result = table.read_modify_write_row(row_key, rules, **kwargs)
if result:
return result._to_dict()
else:
return "None"

@error_safe
async def SampleRowKeys(self, request, **kwargs):
table_id = request["table_name"].split("/")[-1]
app_profile_id = self.app_profile_id or request.get("app_profile_id", None)
table = self.client.get_table(self.instance_id, table_id, app_profile_id)
kwargs["operation_timeout"] = (
kwargs.get("operation_timeout", self.per_operation_timeout) or 20
)
result = table.sample_row_keys(**kwargs)
return result
17 changes: 15 additions & 2 deletions test_proxy/run_tests.sh
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ fi
SCRIPT_DIR=$(realpath $(dirname "$0"))
cd $SCRIPT_DIR

export PROXY_SERVER_PORT=50055
export PROXY_SERVER_PORT=$(shuf -i 50000-60000 -n 1)

# download test suite
if [ ! -d "cloud-bigtable-clients-test" ]; then
Expand All @@ -43,6 +43,19 @@ function finish {
}
trap finish EXIT

if [[ $CLIENT_TYPE == "legacy" ]]; then
echo "Using legacy client"
# legacy client does not expose mutate_row. Disable those tests
TEST_ARGS="-skip TestMutateRow_"
fi

if [[ $CLIENT_TYPE != "async" ]]; then
echo "Using legacy client"
# sync and legacy client do not support concurrent streams
TEST_ARGS="$TEST_ARGS -skip _Generic_MultiStream "
fi

# run tests
pushd cloud-bigtable-clients-test/tests
go test -v -proxy_addr=:$PROXY_SERVER_PORT
echo "Running with $TEST_ARGS"
go test -v -proxy_addr=:$PROXY_SERVER_PORT $TEST_ARGS
5 changes: 4 additions & 1 deletion test_proxy/test_proxy.py
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,9 @@ def format_dict(input_obj):
if client_type == "legacy":
import client_handler_legacy
client = client_handler_legacy.LegacyTestProxyClientHandler(**json_data)
elif client_type == "sync":
import client_handler_data_sync_autogen
client = client_handler_data_sync_autogen.TestProxyClientHandler(**json_data)
else:
client = client_handler_data_async.TestProxyClientHandlerAsync(**json_data)
client_map[client_id] = client
Expand Down Expand Up @@ -150,7 +153,7 @@ def client_handler_process(request_q, queue_pool, client_type="async"):

p = argparse.ArgumentParser()
p.add_argument("--port", dest='port', default="50055")
p.add_argument("--client_type", dest='client_type', default="async", choices=["async", "legacy"])
p.add_argument("--client_type", dest='client_type', default="async", choices=["async", "sync", "legacy"])

if __name__ == "__main__":
port = p.parse_args().port
Expand Down
Loading
Loading