過去幾天,我一直在試圖編寫一個簡單的測試,檢查我的應用程序是否工作。在完成我的程序後,我被介紹給測試人員,這就是爲什麼我在之後編寫測試的原因。Django測試,嘲笑Instagram的響應錯誤
我使用python-Instagram的-EXT作爲庫和Python 3.5.2版
實際的程序正常工作。它只是從instagram獲取數據,將其中的一部分保存到變量中並打印出來。
def handle_instagram(self, max_tag_id, search_string=settings.SEARCH_STRING, return_count=1):
instagram_api = InstagramAPI(access_token=access_token, client_secret=client_secret)
search_string = search_string.replace('#', '')
recent_media, next_ = instagram_api.tag_recent_media(count=5, max_tag_id=None,tag_name=search_string)
id = recent_media[0].id
print(id)
而且這部分工作得很好。但我不希望我的測試從instagram API請求數據,所以我使用模擬來模擬該功能。
from django.test import TestCase
from palautebot.models import Feedback
from django.core.management.base import BaseCommand
from palautebot.management.commands.palautebot import Command
import instagram
import datetime
class TestPalautebotTests(TestCase):
palautebot_cmd = Command()
@mock.patch('palautebot.management.commands.palautebot.InstagramAPI')
def test_handle_instagram(self, palautebot_instagram):
instagram_api = palautebot_instagram.InstagramAPI.return_value
user = instagram.models.User(1234, full_name='Test Account', username='test', profile_picture='http://pic.jpg')
recent_media = [instagram.models.Media(
users_in_photo= [],
comment_count= 0,
link= 'https://www.google.fi',
filter= 'Crema',
caption= instagram.models.Comment(created_at=datetime.datetime(2017, 6, 12, 9, 5, 10), user=user, id='1234', text='#nofilter Instagram test'),
like_count= 0,
id= '0000000000000000001_0000000001',
comments= [],
images= {
'thumbnail': instagram.models.Image('http://www.google.fi', 50, 50),
'low_resolution': instagram.models.Image('http://www.google.fi', 150, 150),
'standard_resolution': instagram.models.Image('http://www.google.fi', 400, 400)
},
tags= [instagram.models.Tag('nofilter')],
likes= [],
user= user,
type= 'image',
user_has_liked= False,
created_time= datetime.datetime(2017, 6, 12, 9, 5, 10))]
next_ = None
instagram_response = (recent_media, next_)
instagram_api.tag_recent_media.return_value = instagram_response
success_list= self.palautebot_cmd.handle_instagram(None, search_string='#nofilter')
self.assertEqual(success_list, [True])
我也有類似的模擬與Facebook API和工作正常,但是當我嘗試這樣做模擬與Instagram的它拋出一個錯誤:
Traceback (most recent call last):
File "/usr/local/lib/python3.5/dist-packages/mock/mock.py", line 1305, in patched
return func(*args, **keywargs)
File "/home/bew/bew/src/palautebot/palautebot/tests.py", line 80, in test_handle_instagram
success_list= self.palautebot_cmd.handle_instagram(None, search_string='#helpalaute')
File "/home/bew/bew/src/palautebot/palautebot/management/commands/palautebot.py", line 162, in handle_instagram
tag_name=search_string
ValueError: not enough values to unpack (expected 2, got 0)
首先,我相信這個問題是與我用作return_value的數據。但是,如果我把它關掉一些,或者嘗試用醃菜將它保存到變量中,這並不重要。在上面的示例中,我使用instagram庫手動生成數據。這些數據與我從Instagram獲得的數據相似。
編輯:原來,python-instagram-ext庫或instagram api中存在一些非常奇怪的事情,因爲max_tag_id不適用於我的id。所以看起來問題可能不在測試中,但與API。
嘗試@ mock.patch(<路徑到視圖> .InstagramAPI') – vZ10
這個程序有沒有好的視圖 – Dosentti
。 handler_intagram方法的路徑 – vZ10