git reimport

This commit is contained in:
2019-03-15 15:02:19 +04:00
commit 742797309a
90 changed files with 4411 additions and 0 deletions

View File

View File

View File

@@ -0,0 +1,56 @@
import json
from datetime import datetime
from zvk.misc.timetable_pb2 import Timetable
import zipfile
import numpy as np
def test_read_timetable_pb():
zfile = zipfile.ZipFile('relics/6407-2.ftt')
timetable_pb_bytes = zfile.read('timetable.pb')
timetable = Timetable.FromString(timetable_pb_bytes)
term_start = datetime.fromtimestamp(timetable.properties.term_start / 1000)
weeks_count = timetable.properties.weeks_count
def convert_weeks(s):
if s == 'a':
return list(range(1, weeks_count + 1))
if s == 'o':
return list(range(1, weeks_count + 1, 2))
if s == 'e':
return list(range(2, weeks_count + 1, 2))
if s.startswith('c'):
return list(map(int, s[1:].split(',')))
raise Exception(f'Bad week identifier {s}')
timetable_dict = {
'term_start': term_start.timestamp(),
'weeks_count': weeks_count,
'lessons': []
}
for lesson in timetable.lesson:
timetable_dict['lessons'].append({
'day': lesson.day,
'time': [lesson.time[:4], lesson.time[4:]],
'weeks': convert_weeks(lesson.weeks),
'subject': timetable.subject[lesson.subject_id - 1].name,
'kind': timetable.kind[lesson.kind_id - 1].name,
'place': timetable.place[lesson.place_id - 1].name,
'teachers': [timetable.teacher[teacher_id - 1].name
for teacher_id in lesson.teacher_id]
})
timetable_json = json.dumps(timetable_dict)
print(timetable_json)
assert 'Дегтярев А. А.' in np.sum([
i['teachers']
for i in timetable_dict['lessons']
])

View File

View File

@@ -0,0 +1,33 @@
import pytest
from zvk.event.consumer import on_startup
from zvk.plugins.vk.command import Argument, command
@on_startup
async def event_emitter(bot):
yield bot.dummy_message_event(',a --inc=100', from_id=111)
yield bot.dummy_message_event(',a --inc=10', from_id=111)
yield bot.dummy_message_event(',a --inc=a', from_id=111)
yield bot.dummy_message_event(',a --inc=1', from_id=123)
@command('a', Argument('--inc', type=int, default=0), permissions=['admin'])
async def command_a(bot, inc):
bot.testing_counter += inc
@pytest.mark.asyncio
async def test_command(bot, api):
api.expect(method_name='messages.send', peer_id=111,
message="🤖: Command .a argument --inc: invalid int value: 'a'")
api.expect(method_name='messages.send', peer_id=123,
message="🤖: Access denied")
bot.event_queue.register_consumer(event_emitter)
bot.event_queue.register_consumer(command_a)
assert await bot.run()
assert bot.testing_counter == 110

View File

@@ -0,0 +1,59 @@
import pytest
from zvk.bot.bot import Bot
from zvk.event.consumer import event_consumer, on_startup
from zvk.event.event import Event
from zvk.plugins.vk.api import VKApi
from zvk.plugins.vk.command_parser import CommandEventType
from zvk.plugins.vk.event_type import VKEventType
@on_startup
async def vk_event_emitter():
yield Event(VKEventType.MESSAGE_NEW,
vk_event_args=[528220, 33, 50951365, 1539933254, 'Я в автобусе щас ваще', {'title': ' ... '}, {}, 0])
yield Event(VKEventType.MESSAGE_NEW,
vk_event_args=[528392, 532481, 2000000049, 1539947094, ',command1', {'from': '363656437'}, {}, 0])
yield Event(VKEventType.MESSAGE_NEW,
vk_event_args=[528393, 532481, 2000000049, 1539947094, ',command2', {'from': '363656437'}, {}, 0])
yield Event(VKEventType.MESSAGE_NEW,
vk_event_args=[528397, 33, 173489181, 1539955700, 'Я литералли ходил на перекур с преподом',
{'fwd_all_count': '0', 'fwd_count': '1', 'title': ' ... '}, {'fwd': '0_0'}, 0])
yield Event(VKEventType.MESSAGE_NEW,
vk_event_args=[540583, 35, 50951365, 1541763627, ',command2 sponge bob square pants', {'title': ' ... '},
{}, 431864521])
yield Event(VKEventType.MESSAGE_NEW,
vk_event_args=[540974, 8227, 2000000055, 1541779800, ',command3 thinking stock imagte',
{'from': '9002294'},
{}, 1729925714])
@event_consumer(consumes=[CommandEventType(command_name='command1')])
async def consumer1(bot):
bot.testing_counter += 1
@event_consumer(consumes=[CommandEventType(command_name='command2')])
async def consumer2(bot):
bot.testing_counter += 2
@event_consumer(consumes=[CommandEventType(command_name='command3')])
async def consumer3(bot, echo):
await echo('chat reply')
@pytest.mark.asyncio
async def test_command_parser(bot: Bot, api: VKApi):
api.expect('messages.send', peer_id=2000000055, message='🤖: chat reply')
bot.event_queue.register_consumer(vk_event_emitter)
bot.event_queue.register_consumer(consumer1)
bot.event_queue.register_consumer(consumer2)
bot.event_queue.register_consumer(consumer3)
assert await bot.run()
assert bot.testing_counter == 5

View File

@@ -0,0 +1,27 @@
import pytest
from zvk.bot.bot import Bot
from zvk.event.consumer import event_consumer, on_startup
from zvk.plugins.vk.api import VKApi
from zvk.plugins.vk.command_parser import CommandEventType
from zvk.util import emoji
@on_startup
async def vk_event_emitter(bot):
yield bot.dummy_message_event('.command1')
@event_consumer(consumes=[CommandEventType(command_name='command1')])
async def command_consumer(echo):
assert (await echo('hi')) == 1
@pytest.mark.asyncio
async def test_echo(bot: Bot, api: VKApi):
api.expect('messages.send', peer_id=123, message=f'{emoji.ROBOT}: hi').set_result(1)
bot.event_queue.register_consumer(vk_event_emitter)
bot.event_queue.register_consumer(command_consumer)
assert await bot.run()

View File

@@ -0,0 +1,49 @@
import pytest
from zvk.plugins.vk.command import Argument, CommandEventConsumer, CommandParseException
def test_signatures_easy():
a = CommandEventConsumer('a', Argument('n', type=int))
assert a.parse_argstring('1') == {'n': 1}
with pytest.raises(Exception):
assert a.parse_argstring('dsa') == {'n': 1}
with pytest.raises(CommandParseException):
assert a.parse_argstring('-h')
with pytest.raises(CommandParseException):
assert a.parse_argstring('dsa')
with pytest.raises(CommandParseException):
assert a.parse_argstring('')
with pytest.raises(CommandParseException):
assert a.parse_argstring('--arg=1')
assert a.parse_argstring('"1"') == {'n': 1}
with pytest.raises(CommandParseException):
assert a.parse_argstring('"')
def test_signatures_complex():
a = CommandEventConsumer('a',
Argument('n', nargs='?', type=int, default=0),
Argument('-n', '--n', dest='m', type=int, default=2),
Argument('-v', action='store_true'),
Argument('--s', type=str))
assert a.parse_argstring('1') == {'n': 1, 'm': 2, 'v': False, 's': None}
assert a.parse_argstring('--n=1') == {'n': 0, 'm': 1, 'v': False, 's': None}
assert a.parse_argstring('--n 1') == {'n': 0, 'm': 1, 'v': False, 's': None}
assert a.parse_argstring('-n 1') == {'n': 0, 'm': 1, 'v': False, 's': None}
assert a.parse_argstring('-vn1') == {'n': 0, 'm': 1, 'v': True, 's': None}
def test_signatures_whole():
a = CommandEventConsumer('a', whole_argstring=True)
assert a.parse_argstring('d ksja jd j jj jj --n -h 2') == {'argstring': 'd ksja jd j jj jj --n -h 2'}

View File

@@ -0,0 +1,27 @@
import pytest
from zvk.event.consumer import on_startup
@on_startup
async def inc(api, bot):
bot.counter += await api.get_magic.inc(type='test')
bot.counter += await api.get_magic.inc(type='test')
bot.counter += await api.get_magic.inc(type='test')
with pytest.raises(ValueError):
await api.get_magic.inc(type='test')
@pytest.mark.asyncio
async def test_api(bot):
bot.api.expect('get_magic.inc', type='test').set_result(1)
bot.api.expect('get_magic.inc', type='test').set_result(2)
bot.api.expect('get_magic.inc', type='*').set_result(3)
bot.counter = 0
bot.event_queue.register_consumer(inc)
assert await bot.run()
assert bot.counter == 6

View File

@@ -0,0 +1,28 @@
import pytest
from zvk.event.consumer import on_startup
from zvk.event.event import Event
from zvk.plugins.vk.event_saver import VKEvent
from zvk.plugins.vk.message_parser import Message
from zvk.util.db import Database
from zvk.plugins.vk.event_type import VKEventType
@on_startup
async def vk_event_emitter():
yield Event(VKEventType.UNREAD_COUNTER_UPDATE, vk_event_args=[3, 0])
yield Event(VKEventType.MESSAGE_NEW, vk_event_args=[528220, 33, 50951365, 1539933254, 'Я в автобусе щас ваще', {'title': ' ... '}, {}, 0])
yield Event(VKEventType.MESSAGE_NEW, vk_event_args=[528392, 532481, 2000000049, 1539947094, 'Где философия?', {'from': '363656437'}, {}, 0])
yield Event(VKEventType.MESSAGE_NEW, vk_event_args=[528397, 33, 173489181, 1539955700, 'Я литералли ходил на перекур с преподом', {'fwd_all_count': '0', 'fwd_count': '1', 'title': ' ... '}, {'fwd': '0_0'}, 0])
@pytest.mark.asyncio
async def test(db: Database, bot, api):
bot.event_queue.register_consumer(vk_event_emitter)
assert await bot.run()
with db as session:
assert session.query(VKEvent).count() == 4
assert session.query(Message).count() == 3

View File

@@ -0,0 +1 @@
a = 1