Added more unit tests

File post, API version selection, HTTP errors
This commit is contained in:
sneakypete81 2013-06-16 12:09:24 +01:00
parent 24fcf3f415
commit b9c947c94c
3 changed files with 177 additions and 12 deletions

View file

@ -0,0 +1 @@
Test File

View file

@ -1,4 +1,5 @@
from __future__ import unicode_literals from __future__ import unicode_literals
import os
import json import json
import httpretty import httpretty
try: try:
@ -15,17 +16,21 @@ class TestHttp(unittest.TestCase):
TEST_DATA = {"message": "Test Message", TEST_DATA = {"message": "Test Message",
"code": 200, "code": 200,
"result": "Test Result"} "result": "Test Result"}
TEST_OAUTH = {"consumer_key": "dummy",
"consumer_secret": "dummy",
"token": "dummy",
"token_secret": "dummy"}
TEST_FILE = os.path.join("tests", "unit", "data", "test_file.txt")
def setUp(self): def setUp(self):
self.client = openphoto.OpenPhoto(host=self.TEST_HOST, self.client = openphoto.OpenPhoto(host=self.TEST_HOST, **self.TEST_OAUTH)
consumer_key="dummy",
consumer_secret="dummy",
token="dummy",
token_secret="dummy")
def _register_uri(self, method, uri=TEST_URI, data=TEST_DATA, **kwds): def _register_uri(self, method, uri=TEST_URI, data=TEST_DATA, body=None,
**kwds):
"""Convenience wrapper around httpretty.register_uri""" """Convenience wrapper around httpretty.register_uri"""
body = json.dumps(data) if body is None:
body = json.dumps(data)
httpretty.register_uri(method, uri=uri, body=body, **kwds) httpretty.register_uri(method, uri=uri, body=body, **kwds)
@staticmethod @staticmethod
@ -94,11 +99,11 @@ class TestHttp(unittest.TestCase):
photo = openphoto.objects.Photo(None, {"id": "photo_id"}) photo = openphoto.objects.Photo(None, {"id": "photo_id"})
album = openphoto.objects.Album(None, {"id": "album_id"}) album = openphoto.objects.Album(None, {"id": "album_id"})
tag = openphoto.objects.Tag(None, {"id": "tag_id"}) tag = openphoto.objects.Tag(None, {"id": "tag_id"})
response = self.client.get(self.TEST_ENDPOINT, self.client.get(self.TEST_ENDPOINT,
photo=photo, album=album, tag=tag, photo=photo, album=album, tag=tag,
list_=[photo, album, tag], list_=[photo, album, tag],
boolean=True, boolean=True,
unicode_="\xfcmlaut") unicode_="\xfcmlaut")
params=self._last_request().querystring params=self._last_request().querystring
self.assertEqual(params["photo"], ["photo_id"]) self.assertEqual(params["photo"], ["photo_id"])
self.assertEqual(params["album"], ["album_id"]) self.assertEqual(params["album"], ["album_id"])
@ -106,3 +111,42 @@ class TestHttp(unittest.TestCase):
self.assertEqual(params["list_"], ["photo_id,album_id,tag_id"]) self.assertEqual(params["list_"], ["photo_id,album_id,tag_id"])
self.assertEqual(params["boolean"], ["1"]) self.assertEqual(params["boolean"], ["1"])
self.assertEqual(params["unicode_"], ["\xc3\xbcmlaut"]) self.assertEqual(params["unicode_"], ["\xc3\xbcmlaut"])
@httpretty.activate
def test_get_with_api_version(self):
self.client = openphoto.OpenPhoto(host=self.TEST_HOST, api_version=1)
self._register_uri(httpretty.GET,
uri="http://%s/v1/%s" % (self.TEST_HOST,
self.TEST_ENDPOINT))
self.client.get(self.TEST_ENDPOINT)
@httpretty.activate
def test_post_with_api_version(self):
self.client = openphoto.OpenPhoto(host=self.TEST_HOST, api_version=1,
**self.TEST_OAUTH)
self._register_uri(httpretty.POST,
uri="http://%s/v1/%s" % (self.TEST_HOST,
self.TEST_ENDPOINT))
self.client.post(self.TEST_ENDPOINT)
@httpretty.activate
def test_post_file(self):
self._register_uri(httpretty.POST)
with open(self.TEST_FILE, 'rb') as in_file:
response = self.client.post(self.TEST_ENDPOINT,
files={"file": in_file})
self.assertEqual(response, self.TEST_DATA)
body = self._last_request().body
self.assertIn("Content-Disposition: form-data; "+
"name=\"file\"; filename=\"test_file.txt\"", body)
self.assertIn("Test File", body)
@httpretty.activate
def test_post_file_parameters_are_sent_as_querystring(self):
self._register_uri(httpretty.POST)
with open(self.TEST_FILE, 'rb') as in_file:
response = self.client.post(self.TEST_ENDPOINT, foo="bar",
files={"file": in_file})
self.assertEqual(response, self.TEST_DATA)
self.assertEqual(self._last_request().querystring["foo"], ["bar"])

View file

@ -0,0 +1,120 @@
from __future__ import unicode_literals
import json
import httpretty
try:
import unittest2 as unittest # Python2.6
except ImportError:
import unittest
import openphoto
from tests.unit.test_http import TestHttp
class TestHttpErrors(TestHttp):
def _register_uri(self, method, uri=TestHttp.TEST_URI,
data=None, body=None, status=200, **kwds):
"""Convenience wrapper around httpretty.register_uri"""
if data is None:
data = self.TEST_DATA
# Set the JSON return code to match the HTTP status
data["code"] = status
if body is None:
body = json.dumps(data)
httpretty.register_uri(method, uri=uri, body=body, status=status,
**kwds)
@httpretty.activate
def test_get_with_error_status_raises_openphoto_exception(self):
self._register_uri(httpretty.GET, status=500)
with self.assertRaises(openphoto.OpenPhotoError):
self.client.get(self.TEST_ENDPOINT)
@httpretty.activate
def test_post_with_error_status_raises_openphoto_exception(self):
self._register_uri(httpretty.POST, status=500)
with self.assertRaises(openphoto.OpenPhotoError):
self.client.post(self.TEST_ENDPOINT)
# TODO: 404 status should raise 404 error, even if JSON is valid
@unittest.expectedFailure
@httpretty.activate
def test_get_with_404_status_raises_404_exception(self):
self._register_uri(httpretty.GET, status=404)
with self.assertRaises(openphoto.OpenPhoto404Error):
response = self.client.get(self.TEST_ENDPOINT)
# TODO: 404 status should raise 404 error, even if JSON is valid
@unittest.expectedFailure
@httpretty.activate
def test_post_with_404_status_raises_404_exception(self):
self._register_uri(httpretty.POST, status=404)
with self.assertRaises(openphoto.OpenPhoto404Error):
response = self.client.post(self.TEST_ENDPOINT)
@httpretty.activate
def test_get_with_invalid_json_raises_exception(self):
self._register_uri(httpretty.GET, body="Invalid JSON")
with self.assertRaises(ValueError):
self.client.get(self.TEST_ENDPOINT)
@httpretty.activate
def test_post_with_invalid_json_raises_exception(self):
self._register_uri(httpretty.POST, body="Invalid JSON")
with self.assertRaises(ValueError):
self.client.post(self.TEST_ENDPOINT)
@httpretty.activate
def test_get_with_error_status_and_invalid_json_raises_openphoto_exception(self):
self._register_uri(httpretty.GET, body="Invalid JSON", status=500)
with self.assertRaises(openphoto.OpenPhotoError):
response = self.client.get(self.TEST_ENDPOINT)
@httpretty.activate
def test_post_with_error_status_and_invalid_json_raises_openphoto_exception(self):
self._register_uri(httpretty.POST, body="Invalid JSON", status=500)
with self.assertRaises(openphoto.OpenPhotoError):
response = self.client.post(self.TEST_ENDPOINT)
@httpretty.activate
def test_get_with_404_status_and_invalid_json_raises_404_exception(self):
self._register_uri(httpretty.GET, body="Invalid JSON", status=404)
with self.assertRaises(openphoto.OpenPhoto404Error):
response = self.client.get(self.TEST_ENDPOINT)
@httpretty.activate
def test_post_with_404_status_and_invalid_json_raises_404_exception(self):
self._register_uri(httpretty.POST, body="Invalid JSON", status=404)
with self.assertRaises(openphoto.OpenPhoto404Error):
response = self.client.post(self.TEST_ENDPOINT)
@httpretty.activate
def test_get_with_duplicate_status_raises_duplicate_exception(self):
data = {"message": "This photo already exists", "code": 409}
self._register_uri(httpretty.GET, data=data, status=409)
with self.assertRaises(openphoto.OpenPhotoDuplicateError):
response = self.client.get(self.TEST_ENDPOINT)
@httpretty.activate
def test_post_with_duplicate_status_raises_duplicate_exception(self):
data = {"message": "This photo already exists", "code": 409}
self._register_uri(httpretty.POST, data=data, status=409)
with self.assertRaises(openphoto.OpenPhotoDuplicateError):
response = self.client.post(self.TEST_ENDPOINT)
# TODO: Status code mismatch should raise an exception
@unittest.expectedFailure
@httpretty.activate
def test_get_with_status_code_mismatch_raises_openphoto_exception(self):
data = {"message": "Test Message", "code": 200}
self._register_uri(httpretty.GET, data=data, status=202)
with self.assertRaises(openphoto.OpenPhotoError):
response = self.client.get(self.TEST_ENDPOINT)
# TODO: Status code mismatch should raise an exception
@unittest.expectedFailure
@httpretty.activate
def test_post_with_status_code_mismatch_raises_openphoto_exception(self):
data = {"message": "Test Message", "code": 200}
self._register_uri(httpretty.POST, data=data, status=202)
with self.assertRaises(openphoto.OpenPhotoError):
response = self.client.post(self.TEST_ENDPOINT)