代码拉取完成,页面将自动刷新
同步操作将从 resolvewang/WeiboSpider 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
import unittest
class TestWeiboSpider(unittest.TestCase):
# 这单元测试写得我很尴尬...
def test_get_login_info(self):
from db import login_info
infos = login_info.get_login_info()
self.assertEquals(len(infos), 8)
def test_login(self):
"""
是测试是否能成功登录的,然后登录后会把cookie保存到redis中
"""
import random
from wblogin.login import get_session
from db.login_info import get_login_info
infos = get_login_info()
info = random.choice(infos)
sc = get_session(info.name, info.password)
if sc:
print('登陆成功')
else:
raise Exception('登录失败')
def test_freeze_account(self):
"""
测试账号被封后是否会去查找还有可用账号没有,这里如果需要测试请换成自己数据库中的账号
"""
from db import login_info
login_info.freeze_account('18708103033')
infos = login_info.get_login_info()
for info in infos:
if info[0] == '18708103033':
self.assertEqual(info.enable, 0)
def test_delete_cookies(self):
"""
测试根据键来删除cookie
"""
from db.redis_db import Cookies
r = Cookies.delete_cookies('18708103033')
self.assertEqual(r, True)
def test_page_get(self):
"""
测试页面抓取功能
"""
from page_get import basic
test_url = 'http://weibo.com/p/1005051764222885/info?mod=pedit_more'
text = basic.get_page(test_url)
self.assertIn('深扒娱乐热点', text)
def test_parse_user_info(self):
"""
测试解析页面功能
"""
from page_parse.user import person, public
from page_get.user import get_user_detail
with open('./tests/writer.html', encoding='utf-8') as f:
cont = f.read()
user = person.get_detail(cont)
user.verify_type = public.get_verifytype(cont)
self.assertEqual(user.verify_type, 1)
self.assertEqual(user.description, '韩寒')
with open('./tests/person.html') as f:
cont = f.read()
user = get_user_detail('222333312', cont)
self.assertEqual(user.follows_num, 539)
def test_get_url_from_web(self):
"""
测试不同类型的用户抓取功能
"""
from page_get import user as user_get
normal_user = user_get.get_profile('1195908387')
self.assertEqual(normal_user.name, '日_推')
writer = user_get.get_profile('1191258123')
self.assertEqual(writer.description, '韩寒')
enterprise_user = user_get.get_profile('1839256234')
self.assertEqual(enterprise_user.level, 36)
def test_get_fans(self):
"""
测试用户粉丝获取功能
"""
from page_parse.user import public
with open('./tests/fans.html', encoding='utf-8') as f:
cont = f.read()
public.get_fans_or_follows(cont)
ids = public.get_fans_or_follows(cont)
self.assertEqual(len(ids), 9)
def test_bulk_insert_with_duplicates(self):
"""
测试批量插入的时候是否会重复插入(请到mysql数据库中查看结果)
"""
from db.seed_ids import insert_seeds
ids = ['2891529877', '2891529878', '281296709']
insert_seeds(ids)
def test_crawl_person_infos(self):
"""
测试
"""
from tasks.user import crawl_person_infos
crawl_person_infos('2041028560')
if __name__ == '__main__':
unittest.main()
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。