Skip to content

Commit

Permalink
test adding to server
Browse files Browse the repository at this point in the history
  • Loading branch information
cowlicks committed Dec 2, 2015
1 parent e2f5b8b commit 9889079
Showing 1 changed file with 42 additions and 1 deletion.
43 changes: 42 additions & 1 deletion blaze/server/tests/test_server.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,8 @@

from odo import odo
from blaze.utils import example
from blaze import discover, symbol, by, CSV, compute, join, into, resource
from blaze import (discover, symbol, by, CSV, compute, join, into, resource,
Data)
from blaze.server.client import mimetype
from blaze.server.server import Server, to_tree, from_tree
from blaze.server.serialization import all_formats
Expand Down Expand Up @@ -50,6 +51,14 @@ def test(server):
yield c


@pytest.yield_fixture
def empty_server():
s = Server(formats=all_formats)
s.app.testing = True
with s.app.test_client() as c:
yield c


def test_datasets(test):
response = test.get('/datashape')
assert response.data.decode('utf-8') == str(discover(data))
Expand Down Expand Up @@ -504,3 +513,35 @@ def test_isin(test, serial):
}
assert result.status_code == 200
assert expected == serial.loads(result.data)


@pytest.mark.parametrize('serial', all_formats)
def test_add_data_to_empty_server(empty_server, serial):
# add data
iris_path = example('iris.csv')
blob = serial.dumps({'iris': iris_path})
response1 = empty_server.post(
'/add',
headers=mimetype(serial),
data=blob,
)
assert 'OK' in response1.status

# check for expected server datashape
response2 = empty_server.get('/datashape')
expected2 = str(discover({'iris': resource(iris_path)}))
assert response2.data.decode('utf-8') == expected2

# compute on added data
t = Data({'iris': resource(iris_path)})
expr = t.iris.petal_length.sum()

response3 = empty_server.post(
'/compute',
data=serial.dumps({'expr': to_tree(expr)}),
headers=mimetype(serial)
)

result3 = serial.loads(response3.data)['data']
expected3 = compute(expr, {'iris': resource(iris_path)})
assert result3 == expected3

0 comments on commit 9889079

Please sign in to comment.