Clean up tests and add a dev key to avoid 403 errors
diff --git a/functional_tests/test_services.py b/functional_tests/test_services.py
index 7457762..205cab1 100644
--- a/functional_tests/test_services.py
+++ b/functional_tests/test_services.py
@@ -20,38 +20,25 @@
import time
import unittest
-# TODO(ade) Remove this mock once the bug in the discovery document is fixed
-DATA_DIR = os.path.join(logging.os.path.dirname(__file__), '../tests/data')
-class HttpMock(object):
-
- def __init__(self, filename, headers):
- f = file(os.path.join(DATA_DIR, filename), 'r')
- self.data = f.read()
- f.close()
- self.headers = headers
-
- def request(self, uri, method="GET", body=None, headers=None, redirections=1, connection_type=None):
- return httplib2.Response(self.headers), self.data
-
class BuzzFunctionalTest(unittest.TestCase):
+ def setUp(self):
+ self.buzz = build('buzz', 'v1', developerKey='AIzaSyD7aEm5tyC9BAdoC-MfL0ol7VV1P4zQgig')
+
def test_can_get_specific_activity(self):
- buzz = build('buzz', 'v1')
- activity = buzz.activities().get(userId='105037104815911535953',
+ activity = self.buzz.activities().get(userId='105037104815911535953',
postId='B:z12sspviqyakfvye123wehng0muwz5jzq04').execute()
self.assertTrue(activity is not None)
def test_can_get_specific_activity_with_tag_id(self):
- buzz = build('buzz', 'v1')
- activity = buzz.activities().get(userId='105037104815911535953',
+ activity = self.buzz.activities().get(userId='105037104815911535953',
postId='tag:google.com,2010:buzz:z13ptnw5usmnv15ey22fzlswnuqoebasu').execute()
self.assertTrue(activity is not None)
def test_can_get_buzz_activities_with_many_params(self):
- buzz = build('buzz', 'v1')
max_results = 2
- activities_command = buzz.activities()
+ activities_command = self.buzz.activities()
activities = activities_command.list(userId='googlebuzz', scope='@self',
max_comments=max_results*2 ,max_liked=max_results*3,
max_results=max_results).execute()
@@ -63,9 +50,8 @@
self.assertEquals(max_results, activity_count)
def test_can_get_multiple_pages_of_buzz_activities(self):
- buzz = build('buzz', 'v1')
max_results = 2
- activities_command = buzz.activities()
+ activities_command = self.buzz.activities()
activities = activities_command.list(userId='adewale', scope='@self',
max_results=max_results).execute()
@@ -74,26 +60,24 @@
activity_count = len(activities['items'])
self.assertEquals(max_results, activity_count, 'Failed after %s pages' % str(count))
- def IGNORE__test_can_get_multiple_pages_of_buzz_likers(self):
+ def IGNORE_test_can_get_multiple_pages_of_buzz_likers(self):
# Ignore this test until the Buzz API fixes the bug with next links
# http://code.google.com/p/google-buzz-api/issues/detail?id=114
- self.http = HttpMock('buzz.json', {'status': '200'})
- buzz = build('buzz', 'v1', self.http)
max_results = 1
- people_cmd = buzz.people()
+ people_cmd = self.buzz.people()
# The post https://www.googleapis.com/buzz/v1/activities/111062888259659218284/@self/B:z13nh535yk2syfob004cdjyb3mjeulcwv3c?alt=json#
#Perform this call https://www.googleapis.com/buzz/v1/activities/111062888259659218284/@self/B:z13nh535yk2syfob004cdjyb3mjeulcwv3c/@liked?alt=json&max-results=1
people = people_cmd.liked(groupId='@liked', userId='googlebuzz', scope='@self',
postId='B:z13nh535yk2syfob004cdjyb3mjeulcwv3c', max_results=max_results).execute()
for count in range(10):
+ print count
people = people_cmd.liked_next(people).execute()
people_count = len(people['items'])
self.assertEquals(max_results, people_count, 'Failed after %s pages' % str(count))
def test_can_get_user_profile(self):
- buzz = build('buzz', 'v1')
- person = buzz.people().get(userId='googlebuzz').execute()
+ person = self.buzz.people().get(userId='googlebuzz').execute()
self.assertTrue(person is not None)
self.assertEquals('buzz#person', person['kind'])
@@ -102,8 +86,7 @@
self.assertEquals('https://profiles.google.com/googlebuzz', person['profileUrl'])
def test_can_get_user_profile_using_numeric_identifier(self):
- buzz = build('buzz', 'v1')
- person = buzz.people().get(userId='108242092577082601423').execute()
+ person = self.buzz.people().get(userId='108242092577082601423').execute()
self.assertTrue(person is not None)
self.assertEquals('buzz#person', person['kind'])
@@ -112,18 +95,16 @@
self.assertEquals('https://profiles.google.com/108242092577082601423', person['profileUrl'])
def test_can_get_followees_of_user(self):
- buzz = build('buzz', 'v1')
expected_followees = 30
- following = buzz.people().list(userId='googlebuzz', groupId='@following', max_results=expected_followees).execute()
+ following = self.buzz.people().list(userId='googlebuzz', groupId='@following', max_results=expected_followees).execute()
self.assertEquals(expected_followees, following['totalResults'])
self.assertEquals(expected_followees, len(following['entry']))
def test_can_efficiently_get_follower_count_of_user(self):
- buzz = build('buzz', 'v1')
# Restricting max_results to 1 means only a tiny amount of data comes back but the totalResults still has the total.
- followers = buzz.people().list(userId='googlebuzz', groupId='@followers',
+ followers = self.buzz.people().list(userId='googlebuzz', groupId='@followers',
max_results='1').execute()
# @googlebuzz has a large but fluctuating number of followers
@@ -132,8 +113,7 @@
self.assertTrue(follower_count > 10000, follower_count)
def test_follower_count_is_missing_for_user_with_hidden_follower_count(self):
- buzz = build('buzz', 'v1')
- followers = buzz.people().list(userId='adewale', groupId='@followers').execute()
+ followers = self.buzz.people().list(userId='adewale', groupId='@followers').execute()
self.assertFalse('totalResults' in followers)
@@ -147,11 +127,11 @@
f.close()
self.http = credentials.authorize(httplib2.Http())
+ self.buzz = build('buzz', 'v1', http=self.http, developerKey='AIzaSyD7aEm5tyC9BAdoC-MfL0ol7VV1P4zQgig')
def test_can_create_activity(self):
- buzz = build('buzz', 'v1', http=self.http)
- activity = buzz.activities().insert(userId='@me', body={
+ activity = self.buzz.activities().insert(userId='@me', body={
'data': {
'title': 'Testing insert',
'object': {
@@ -163,9 +143,7 @@
self.assertTrue(activity is not None)
def test_can_create_private_activity(self):
- buzz = build('buzz', 'v1', http=self.http)
-
- activity = buzz.activities().insert(userId='@me', body={
+ activity = self.buzz.activities().insert(userId='@me', body={
'data': {
'title': 'Testing insert',
'object': {
@@ -182,29 +160,26 @@
self.assertTrue(activity is not None)
def test_can_create_and_delete_new_group(self):
- buzz = build('buzz', 'v1', http=self.http)
group_name = 'New Group Created At' + str(time.time())
- group = buzz.groups().insert(userId='@me', body = {
+ group = self.buzz.groups().insert(userId='@me', body = {
'data': {
'title': group_name
}
}).execute()
self.assertTrue(group is not None)
- result = buzz.groups().delete(userId='@me', groupId=group['id']).execute()
+ result = self.buzz.groups().delete(userId='@me', groupId=group['id']).execute()
self.assertEquals({}, result)
def test_can_identify_number_of_groups_belonging_to_user(self):
- buzz = build('buzz', 'v1', http=self.http)
- groups = buzz.groups().list(userId='108242092577082601423').execute()
+ groups = self.buzz.groups().list(userId='108242092577082601423').execute()
# This should work as long as no-one deletes the 4 default groups for this test account
expected_default_number_of_groups = 4
self.assertTrue(len(groups['items']) > expected_default_number_of_groups)
def IGNORE__test_can_like_activity(self):
- buzz = build('buzz', 'v1', http=self.http)
- activity = buzz.activities().insert(userId='@me', body={
+ activity = self.buzz.activities().insert(userId='@me', body={
'data': {
'title': 'Testing insert',
'object': {
@@ -215,13 +190,11 @@
).execute()
pprint.pprint(activity)
id = activity['id']
- likers = buzz.people().liked(userId='105037104815911535953', postId=id, groupId='@liked', scope='@self').execute()
+ likers = self.buzz.people().liked(userId='105037104815911535953', postId=id, groupId='@liked', scope='@self').execute()
# Todo(ade) Insert the new liker once the Buzz back-end bug is fixed
def test_can_comment_on_activity(self):
- buzz = build('buzz', 'v1', http=self.http)
-
- activity = buzz.activities().insert(userId='@me', body={
+ activity = self.buzz.activities().insert(userId='@me', body={
'data': {
'title': 'A new activity',
'object': {
@@ -232,32 +205,29 @@
).execute()
id = activity['id']
- comment = buzz.comments().insert(userId='@me', postId=id, body={
+ comment = self.buzz.comments().insert(userId='@me', postId=id, body={
'data': {
'content': 'A comment on the new activity'
}
}).execute()
def test_can_list_groups_belonging_to_user(self):
- buzz = build('buzz', 'v1', http=self.http)
- groups = buzz.groups().list(userId='108242092577082601423').execute()
+ groups = self.buzz.groups().list(userId='108242092577082601423').execute()
- group = buzz.groups().get(userId='108242092577082601423', groupId='G:108242092577082601423:15').execute()
+ group = self.buzz.groups().get(userId='108242092577082601423', groupId='G:108242092577082601423:15').execute()
self.assertEquals('G:108242092577082601423:15', group['id'], group)
- group = buzz.groups().get(userId='108242092577082601423', groupId='G:108242092577082601423:14').execute()
+ group = self.buzz.groups().get(userId='108242092577082601423', groupId='G:108242092577082601423:14').execute()
self.assertEquals('G:108242092577082601423:14', group['id'], group)
- group = buzz.groups().get(userId='108242092577082601423', groupId='G:108242092577082601423:13').execute()
+ group = self.buzz.groups().get(userId='108242092577082601423', groupId='G:108242092577082601423:13').execute()
self.assertEquals('G:108242092577082601423:13', group['id'], group)
- group = buzz.groups().get(userId='108242092577082601423', groupId='G:108242092577082601423:6').execute()
+ group = self.buzz.groups().get(userId='108242092577082601423', groupId='G:108242092577082601423:6').execute()
self.assertEquals('G:108242092577082601423:6', group['id'], group)
def test_can_delete_activity(self):
- buzz = build('buzz', 'v1', http=self.http)
-
- activity = buzz.activities().insert(userId='@me', body={
+ activity = self.buzz.activities().insert(userId='@me', body={
'data': {
'title': 'Activity to be deleted',
'object': {
@@ -268,7 +238,7 @@
).execute()
id = activity['id']
- buzz.activities().delete(scope='@self', userId='@me', postId=id).execute()
+ self.buzz.activities().delete(scope='@self', userId='@me', postId=id).execute()
time.sleep(2)
activity_url = activity['links']['self'][0]['href']