Skip to content
This repository has been archived by the owner on Jan 28, 2021. It is now read-only.

Commit

Permalink
Add integration script
Browse files Browse the repository at this point in the history
Signed-off-by: kuba-- <kuba@sourced.tech>
  • Loading branch information
kuba-- committed Jan 28, 2019
1 parent 8d42337 commit 9ae39c2
Show file tree
Hide file tree
Showing 5 changed files with 47 additions and 0 deletions.
14 changes: 14 additions & 0 deletions SUPPORTED_CLIENTS.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ These are the clients we actively test against to check are compatible with go-m
- Python
- [pymysql](#pymysql)
- [mysql-connector](#python-mysql-connector)
- [sqlalchemy](#python-sqlalchemy)
- Ruby
- [ruby-mysql](#ruby-mysql)
- [PHP](#php)
Expand Down Expand Up @@ -65,6 +66,19 @@ finally:
connection.close()
```

### Python sqlalchemy

```python
import pandas as pd
import sqlalchemy

engine = sqlalchemy.create_engine('mysql+pymysql://user:pass@127.0.0.1:3306/dbname')
with engine.connect() as conn:
repo_df = pd.read_sql_table("mytable", con=conn)
for table_name in repo_df.to_dict():
print(table_name)
```

### ruby-mysql

```ruby
Expand Down
7 changes: 7 additions & 0 deletions _integration/python-sqlalchemy/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
dependencies:
python -m pip install -r requirements.txt

test: dependencies
python -m unittest discover

.PHONY: dependencies test
2 changes: 2 additions & 0 deletions _integration/python-sqlalchemy/requirements.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
pandas
sqlalchemy
24 changes: 24 additions & 0 deletions _integration/python-sqlalchemy/test.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
import unittest
import pandas as pd
import sqlalchemy


class TestMySQL(unittest.TestCase):

def test_connect(self):
engine = sqlalchemy.create_engine('mysql+pymysql://user:pass@127.0.0.1:3306/test')
with engine.connect() as conn:
expected = {
"name": {0: 'John Doe', 1: 'John Doe', 2: 'Jane Doe', 3: 'Evil Bob'},
"email": {0: 'john@doe.com', 1: 'johnalt@doe.com', 2: 'jane@doe.com', 3: 'evilbob@gmail.com'},
"phone_numbers": {0: '["555-555-555"]', 1: '[]', 2: '[]', 3: '["555-666-555","666-666-666"]'},
"created_at": {0: pd.Timestamp('2019-01-28 15:35:51'), 1: pd.Timestamp('2019-01-28 15:35:51'), 2: pd.Timestamp('2019-01-28 15:35:51'), 3: pd.Timestamp('2019-01-28 15:35:51')},
}

repo_df = pd.read_sql_table("mytable", con=conn)

self.assertEqual(expected, repo_df.to_dict())


if __name__ == '__main__':
unittest.main()
Binary file added test-server
Binary file not shown.

0 comments on commit 9ae39c2

Please sign in to comment.