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

Graph Support for Python Connector #3

Open
wants to merge 166 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
166 commits
Select commit Hold shift + click to select a range
fdd5418
WIP: Start driver for the new gRPC based interface of Polypheny
gartens Dec 22, 2023
807676a
WIP: Add requirements file
gartens Jan 23, 2024
5cafbae
WIP: Various improvements and reformat
gartens Jan 26, 2024
897ca25
WIP: Add test for PEP
gartens Jan 26, 2024
edc7671
WIP: Add setup.py
gartens Jan 26, 2024
0c62a2c
WIP: Remove comment
gartens Jan 26, 2024
fc7af44
WIP: Ignore IDEA folder
gartens Jan 26, 2024
f545137
WIP: 90% test coverage
gartens Feb 12, 2024
1072def
WIP: make mql db.find() work
gartens Feb 12, 2024
db1cbf0
WIP: Update protofiles
gartens Feb 12, 2024
2a3ceef
WIP: Remove obsolete workaround & add explicit close of self.chan on …
gartens Feb 26, 2024
23dd30c
WIP: Add test and extend README on how to run tests with coverage
gartens Feb 26, 2024
02a8412
Connection works again
gartens Feb 27, 2024
19b64ab
Commit, Rollback and Disconnect
gartens Feb 27, 2024
e1c718b
All test pass again
gartens Feb 27, 2024
d242c3a
Bring test coverage back to >90%
gartens Feb 27, 2024
b9a788e
Remove unused import & streamline connect RPC with other RPC calls
gartens Feb 27, 2024
9d826f7
Format and fix various warnings,problems etc. found with PyCharm
gartens Feb 27, 2024
fb728de
Rename table for consistency with other tests
gartens Feb 29, 2024
bc431f5
Send the initial fetch_size for each fetch request
gartens Feb 29, 2024
39d2ca9
Rewrite tests in test_conn to no longer use emp table
gartens Feb 29, 2024
15cc9bb
Streamline the execute function and properly handle results of DDLs/DMLs
gartens Feb 29, 2024
0d720c0
Move assert back into the main path
gartens Feb 29, 2024
d563481
Replace emp usage in test_pep with data created by the tests
gartens Feb 29, 2024
2de2a3e
Prevent disconnect message when an error during connect occurs
gartens Mar 1, 2024
ca3a4e2
Add two assertions for correct rowcount of DMLs
gartens Mar 1, 2024
9dbd909
Sync protobuf files
gartens Mar 1, 2024
6891192
Sync protobuf files
gartens Mar 4, 2024
10bb0e0
Initialize con early to prevent errors during destruction
gartens Mar 7, 2024
7713bf0
Add Transport class to wrap connection specific information
gartens Mar 7, 2024
21de185
Remove protobuf files
gartens Mar 13, 2024
ac33b1a
Remove gRPC dependency
gartens Mar 13, 2024
8914f1c
Add test dependencies
gartens Mar 13, 2024
f29ae98
Move code into a proper package
gartens Mar 13, 2024
7ec5882
Reduce duplication in test_helper
gartens Mar 13, 2024
9f305f7
Update README
gartens Mar 13, 2024
3bacb14
Use package for protobuf definitions
gartens Mar 13, 2024
0b9241b
Remove leftover protobuf file
gartens Mar 13, 2024
aa811b1
Add Unix Transport
gartens Mar 8, 2024
5ce7c2b
Add date/time support
gartens Mar 8, 2024
7f9cd42
Update to recent date changes
gartens Mar 19, 2024
9d0782a
Update serializer.py
gartens Mar 19, 2024
35d7727
Add interval support
gartens Mar 19, 2024
dd612aa
Fix a skipped test
gartens Mar 19, 2024
25088ee
Ignore coverage file
gartens Mar 19, 2024
58de2be
Change interval to only contain months or milliseconds
gartens Mar 20, 2024
2a4a568
Add interval tests
gartens Mar 20, 2024
6e95446
Update to protobuf changes
gartens Mar 20, 2024
0f49e03
Start with documentation
gartens Mar 21, 2024
149e9d1
Add test workflow
gartens Mar 21, 2024
916d76d
Update README.md
gartens Mar 21, 2024
be96522
Add option to spawn a Polypheny instance for tests
gartens Mar 21, 2024
079625e
Fix workflow
gartens Mar 21, 2024
94e5b7f
Add interval.py
gartens Mar 21, 2024
9ba021c
Move line that got into the wrong spot during rebase
gartens Mar 21, 2024
211a496
Print output when starting Polypheny fails
gartens Mar 21, 2024
9bdec50
Add return type
gartens Mar 22, 2024
185bc2a
Make doctest output deterministic
gartens Mar 22, 2024
b15847e
Add an intro to the docs and test examples
gartens Mar 22, 2024
c331318
Change scope of doctest fixture
gartens Mar 22, 2024
75f4551
Fix source links and small wording change for intervals
gartens Mar 22, 2024
32ce1ba
Update .gitignore
gartens Mar 22, 2024
b966ff0
Add matrix to test multiple Python versions
gartens Mar 22, 2024
04b5898
Use correct protoc version
gartens Mar 22, 2024
9c8a9a0
Add timeout to jobs and add -v to pytest
gartens Mar 25, 2024
25592c4
Improve types documentation
gartens Mar 25, 2024
5d53d06
Test on macOS
gartens Mar 25, 2024
8ca4999
Run tests on all systems
gartens Mar 25, 2024
116e1b4
Small improvements to types.md
gartens Mar 25, 2024
7fb8308
Update README.md
gartens Mar 25, 2024
df09c1b
Use polyphenyprism as a package, not with relative import
gartens Mar 27, 2024
2f39000
Use the .polypheny unix listener for tests
gartens Mar 27, 2024
217ea50
Remove unused imports
gartens Mar 27, 2024
d3e6c8c
Add tests for future versions of Polypheny
gartens Mar 27, 2024
8ec72dd
Add tests for cypher, cql and pig
gartens Mar 27, 2024
c16fa31
Add a namespace parameter to executeany
gartens Mar 27, 2024
bec8b30
Remove tests that were moved
gartens Mar 28, 2024
97bd1c0
Test negative integers as well
gartens Mar 28, 2024
8d5580d
Cleanup/improve some old tests
gartens Mar 28, 2024
40ac56a
Add more broken tests
gartens Mar 28, 2024
bf508f5
Test different adapters as well
gartens Mar 28, 2024
fd6cd0b
Improve decimal serialization
gartens Mar 28, 2024
7676e20
Remove debug print
gartens Apr 4, 2024
87eca37
Update for interval change
gartens Apr 9, 2024
4a5a19b
Improve connection signature
gartens Apr 9, 2024
2ca8395
Fix typo in serialize
gartens Apr 10, 2024
d18a309
Use new style connect for doctests
gartens Apr 10, 2024
492d74f
Type annotation fix for Python 3.8
gartens Apr 10, 2024
368d346
Promote unix and mention its limitations
gartens Apr 10, 2024
92d52bd
Move a now working test back to test_serialize
gartens Apr 10, 2024
9d01b87
Unix sockets do not work on Windows with Python
gartens Apr 10, 2024
a048814
Various linter fixes & formatting
gartens Apr 11, 2024
f17aedd
Test connect without arguments as well
gartens Apr 11, 2024
59126a1
Generate docs as part of the workflow
gartens Apr 11, 2024
c987c8e
Use unique id values
gartens Apr 11, 2024
aac7a11
Adjust timeout for build-docs
gartens Apr 11, 2024
d8f43aa
Remove three todos
gartens Apr 11, 2024
27c4579
Add test for plain transport
gartens Apr 11, 2024
4df88d8
Enable two skipped tests and add a new one
gartens Apr 11, 2024
2f7539a
Improve BigDecimal deserialization
gartens Apr 12, 2024
6341b30
Pig works now
gartens Apr 16, 2024
de3b9b8
Be stricter for default unix transport case
gartens Apr 16, 2024
892a01d
Fix array test
gartens Apr 16, 2024
172cae5
Add version exchange
gartens Apr 18, 2024
db5aa6a
Change BigDecimal deserialization
gartens Apr 18, 2024
5d1b1f5
Enable tests that are now working
gartens Apr 18, 2024
c3907a9
Set TCP_NODELAY option
gartens Apr 18, 2024
d2e0823
Fix merge error
gartens Apr 18, 2024
cfd781d
Remove unused variable
gartens Apr 18, 2024
1cf4e55
Fix tests by using the new Run-Polypheny action
gartens Apr 30, 2024
9e36381
Remove leftover from when Polypheny was started within tests
gartens Apr 30, 2024
5d379b4
Use new Run-Polypheny action to test different adapters
gartens Apr 30, 2024
4db861f
Use new version of action plugin
gartens Apr 30, 2024
cdc739c
Update for polyprism package changes
gartens May 6, 2024
89d9d74
Adjust build command for protofiles
gartens May 6, 2024
be69d1d
Fix typo
gartens May 6, 2024
0f0d5c7
Update imports
gartens May 6, 2024
73573e7
Set version environment variable when installing polyphenyprism
gartens May 6, 2024
e49a533
Update package name of prism api package
gartens May 7, 2024
ca5d570
Drop protobuf dependencies (pulled in via the api package)
gartens May 7, 2024
820a742
Move working test out of test_future
gartens May 7, 2024
f53c316
Update version variable
gartens May 8, 2024
638b64d
Update publish workflow
vogti May 10, 2024
b4f29d6
Add a comment
gartens May 13, 2024
501ce29
Use new GitHub action to build Polypheny
gartens May 13, 2024
ddbdfd6
Use correct JAR for documentation tests
gartens May 13, 2024
94b6c81
Use correct JAR filename
gartens May 13, 2024
8258d54
moved working large number tests into correct file
datomo May 13, 2024
05cb68f
adjusted handling for too large numeric values
datomo May 13, 2024
6db7b87
fix incorrect create table statement
datomo May 14, 2024
c8410f5
moved future test double
datomo May 14, 2024
91deda3
excluded large2 for monetdb
datomo May 15, 2024
f2f2701
added missing import
datomo May 15, 2024
1aa82f3
fixed incorrect function
datomo May 15, 2024
710b20b
adjusted variable and set it for job step
datomo May 15, 2024
04777f6
added adjustement to serialize test
datomo May 15, 2024
e0d2421
adjusted casing
datomo May 15, 2024
a5909b6
added github system env variable
datomo May 15, 2024
ae2ba4d
Convert decimals to integers if possible
gartens May 16, 2024
f3d6243
Update readme
vogti May 16, 2024
ecf550a
Adjust workflow
vogti May 16, 2024
69e37bd
Fix publish workflow
vogti May 16, 2024
de15aed
Delete protoc file
vogti May 16, 2024
ac1fa7c
Add license header
gartens May 17, 2024
ad1b763
Use prism api version 1.5 from pypi
vogti May 17, 2024
5eeffc4
Bump prism-api version to 1.6
vogti May 17, 2024
e9c3b3d
Use setuptools
vogti May 17, 2024
42bdf7a
Explicitly set version=0.1 in tests
vogti May 17, 2024
9dc74b0
Change variable to RELEASE_VERSION
vogti May 17, 2024
3092291
Bump prism-api version to 1.9
vogti May 17, 2024
549b9a7
Adjust publish workflow
vogti May 17, 2024
efe32aa
Fix path in workflow
vogti May 17, 2024
f716bf5
added setup info
hennlo May 18, 2024
4fe2d12
changed version
hennlo May 21, 2024
9a5d735
changed test structure
hennlo May 21, 2024
5e66ed1
updated readme
hennlo May 21, 2024
f06ab1b
Add graph result case
Jun 27, 2024
9a599d9
Add node and edge deserialization
Jul 4, 2024
794fde3
Add tests
Jul 4, 2024
4a9d8fd
Add graph demo
Jul 5, 2024
1ace3f1
Update api version
Jul 18, 2024
bbc6e70
Bump api version
Jul 31, 2024
fff878e
Remove unused code
Jul 31, 2024
9c58170
Adjust api version
Aug 11, 2024
7bf2ad8
Add feature vector and properties to connection method
Aug 11, 2024
65b12bc
Adjust graph deserialization
Aug 11, 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
63 changes: 26 additions & 37 deletions .github/workflows/publish-to-pypi.yml
Original file line number Diff line number Diff line change
@@ -1,39 +1,28 @@
name: Publish Python 🐍 distributions 📦 to PyPI and TestPyPI

name: Publish Python 🐍 distributions 📦 to PyPI
on:
# Trigger the workflow on push , PR or release publish,
# but only for the main branch
push:
branches:
- master
pull_request:
branches:
- master
release:
types:
- published
- released

release:
types:
- published
jobs:
build-n-publish:
name: Build and publish Python 🐍 distributions 📦 to PyPI and TestPyPI
runs-on: ubuntu-18.04
steps:
- uses: actions/checkout@master
- name: Set up Python 3.9
uses: actions/setup-python@v1
with:
python-version: 3.9
- name: Build package
run: python setup.py sdist
- name: Publish distribution 📦 to Test PyPI
if: github.event_name == 'push'
uses: pypa/gh-action-pypi-publish@master
with:
password: ${{ secrets.TEST_PYPI_API_TOKEN }}
repository_url: https://test.pypi.org/legacy/
- name: Publish distribution 📦 to PyPI
if: github.event_name == 'release'
uses: pypa/gh-action-pypi-publish@master
with:
password: ${{ secrets.PYPI_API_TOKEN }}
publish:
name: Build and publish Python 🐍 distributions 📦 to PyPI and TestPyPI
runs-on: ubuntu-latest
permissions:
contents: write
packages: write
id-token: write
steps:
- uses: actions/checkout@v4
- name: Set up Python 3.8
uses: actions/setup-python@v5
with:
python-version: 3.8
- name: Set Version
id: version
run: echo "${GITHUB_REF#refs/tags/}" > polypheny-connector-version.txt
- name: Create MANIFEST.in
run: echo "include polypheny-connector-version.txt" > MANIFEST.in
- name: Build package
run: python setup.py sdist
- name: Publish distribution 📦 to PyPI
uses: pypa/gh-action-pypi-publish@release/v1
171 changes: 171 additions & 0 deletions .github/workflows/test.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,171 @@
name: Runs the tests

on:
push:
branches:
- proto-without-grpc

jobs:
build-polypheny:
timeout-minutes: 15
runs-on: ubuntu-latest
steps:
- uses: polypheny/GitHub-Action-Build-Polypheny@main
with:
branch: master

test-system-python:
timeout-minutes: 10
strategy:
fail-fast: false
matrix:
version: ['3.8', '3.9', '3.10', '3.11', '3.12'] # TODO: When dropping 3.8, adjust type hints for polypheny.connect
os: [ubuntu-latest, macos-latest, windows-latest]
runs-on: ${{ matrix.os }}
needs: build-polypheny
steps:
- uses: actions/setup-python@v5
with:
python-version: ${{ matrix.version }}

- uses: actions/setup-java@v4
with:
distribution: 'temurin'
java-version: '17'

- name: Checkout driver
uses: actions/checkout@v4

- name: Set Version
id: version
run: echo "v0.0.0" > polypheny-connector-version.txt

- name: Create MANIFEST.in
run: echo "include polypheny-connector-version.txt" > MANIFEST.in

- name: Install driver dependencies
run: pip install -r requirements.txt

- name: Load Polypheny JAR
uses: actions/download-artifact@v4
with:
name: polypheny-jar

- name: Run tests
uses: polypheny/[email protected]
with:
cmd: pytest --doctest-modules -v
jar: polypheny.jar
autodocker: ${{ matrix.os != 'windows' }}
timeout-minutes: 10

- name: Install locally
run: pip install .

- name: Run tests in docs
uses: polypheny/[email protected]
with:
cmd: make doctest
jar: ../polypheny.jar
autodocker: ${{ matrix.os != 'windows' }}
working-directory: docs

test-stores:
timeout-minutes: 10
strategy:
fail-fast: false
matrix:
adapter: [ mongodb, hsqldb, monetdb, postgresql, file, cottontail, neo4j ]
runs-on: ubuntu-latest
needs: build-polypheny
steps:
- name: Set store env variable
run: |
echo "DEFAULT_STORE=${{ matrix.adapter }}" >> $GITHUB_ENV
- uses: actions/setup-python@v5
with:
python-version: '3.12'

- uses: actions/setup-java@v4
with:
distribution: 'temurin'
java-version: '17'

- name: Checkout driver
uses: actions/checkout@v4

- name: Set Version
id: version
run: echo "v0.0.0" > polypheny-connector-version.txt

- name: Create MANIFEST.in
run: echo "include polypheny-connector-version.txt" > MANIFEST.in

- name: Install driver dependencies
run: pip install -r requirements.txt

- name: Load Polypheny JAR
uses: actions/download-artifact@v4
with:
name: polypheny-jar

- name: Run tests
uses: polypheny/[email protected]
with:
cmd: pytest --doctest-modules -v
jar: polypheny.jar
default-store: ${{ matrix.adapter }}
timeout-minutes: 10

- name: Install locally
run: pip install .

- name: Run tests in docs
uses: polypheny/[email protected]
with:
cmd: make doctest
jar: ../polypheny.jar
working-directory: docs
default-store: ${{ matrix.adapter }}

build-docs:
timeout-minutes: 2
runs-on: ubuntu-latest
steps:
- uses: actions/setup-python@v5
with:
python-version: '3.12'

- name: Checkout driver
uses: actions/checkout@v4

- name: Set Version
id: version
run: echo "v0.0.0" > polypheny-connector-version.txt

- name: Create MANIFEST.in
run: echo "include polypheny-connector-version.txt" > MANIFEST.in

- name: Install driver dependencies
run: pip install -r requirements.txt

- name: Install markdown generator
run: pip install sphinx-markdown-builder

- name: Install locally
run: pip install .

- name: Generate documentation (markdown)
run: make markdown
working-directory: docs

- name: Generate documentation (HTML)
run: make html
working-directory: docs

- name: Store docs
uses: actions/upload-artifact@v4
with:
name: docs
path: docs/_build

12 changes: 9 additions & 3 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -19,11 +19,11 @@ sdist/
var/
.installed.cfg
/dist/
/doc/_build/
/docs/_build/
/doc/build/
*.pyc
debug.py
*.proto
#*.proto
polypheny-avatica-tmp/

# core dumps
Expand All @@ -32,4 +32,10 @@ core.*
# Editor specific
.vscode

.DS_STORE
.DS_STORE

venv/

.idea

.coverage
43 changes: 0 additions & 43 deletions CHANGELOG.md

This file was deleted.

Loading