예제 #1
0
    def test_click_event_for_remind_today(self):
        req_text = """
        <xml>
        <ToUserName><![CDATA[toUser]]></ToUserName>
        <FromUserName><![CDATA[FromUser]]></FromUserName>
        <CreateTime>123456789</CreateTime>
        <MsgType><![CDATA[event]]></MsgType>
        <Event><![CDATA[CLICK]]></Event>
        <EventKey><![CDATA[time_remind_today]]></EventKey>
        </xml>
        """
        wechat_msg = self.build_wechat_msg(req_text)
        resp_xml = handle_message(wechat_msg)
        self.assertIn('今天没有提醒', resp_xml)
        WechatUser(openid='abc', nickname='abc').save()
        r = Remind(time=timezone.now(), owner_id=self.user.pk, event='睡觉')
        r.save()
        resp_xml = handle_message(wechat_msg)
        self.assertIn(r.title(), resp_xml)
        self.assertIn(r.local_time_string('G:i'), resp_xml)

        r = Remind(time=timezone.now(),
                   owner_id=self.user.pk,
                   event='吃饭',
                   participants=['abc'])
        r.save()
        self.assertEqual(
            WechatUser.objects.get(pk='abc').get_time_reminds().first(), r)
예제 #2
0
 def test_default_title(self):
     r = Remind(time=timezone.now(), owner_id='miao', desc='吃饭饭', done=True)
     r.save()
     serializer = RemindSerializer(instance=r,
                                   context={'request': self.request})
     with HTTMock(access_token_mock, create_qrcode_mock):
         self.assertEqual(serializer.data['title'], Remind.default_title)
예제 #3
0
 def setUp(self):
     self.r = Remind(time=timezone.now(),
                     owner_id='miao',
                     event='吃饭',
                     desc='吃饭饭',
                     done=True)
     self.r.save()
예제 #4
0
 def setUp(self):
     self.user = WechatUser(openid='miao', nickname='456')
     self.user.save()
     self.r = Remind(time=timezone.now(),
                     owner_id='miao',
                     event='吃饭',
                     desc='吃饭饭')
     self.r.save()
예제 #5
0
 def test_notify_time_update(self):
     n = timezone.now()
     r = Remind(time=n, owner_id='miao', event='吃饭', desc='吃饭饭')
     r.save()
     self.assertEqual(r.notify_time, n)
     r.defer = -10
     r.save()
     self.assertEqual(r.notify_time, n - timedelta(minutes=10))
     self.assertEqual(r.nature_time_defer(), '提前 10 分钟')
예제 #6
0
    def test_lines_with_carriage(self):
        desc = """2018 NEO编程日 第1站  时间:2018年1月13日13:00(签到)—18:30(下午)""" + \
            """\n地点:上海浦东新区金科路长泰广场C座12层
                    """
        r = Remind(time=timezone.now(), owner_id='miao', event='吃饭', desc=desc)
        image = draw_post(r, self.user)

        if DISPLAY_POST:
            image.show()
예제 #7
0
    def test_many_lines_description(self):
        r = Remind(time=timezone.now(),
                   owner_id='miao',
                   event='吃饭',
                   desc='吃饭饭' * 50)
        image = draw_post(r, self.user)

        if DISPLAY_POST:
            image.show()
예제 #8
0
    def test_add_add_participant(self):
        r = Remind(time=timezone.now(),
                   owner_id='miao',
                   event='吃饭',
                   desc='吃饭饭')
        r.save()
        r.add_participant('abc')
        r.add_participant('abc')

        self.assertEqual(r.participants, ['abc'])
예제 #9
0
 def test_reschedule(self):
     n = timezone.now() - timedelta(minutes=10)
     r = Remind(time=n,
                owner_id='miao',
                event='吃饭',
                desc='吃饭饭',
                repeat={REPEAT_KEY_DAY: 1},
                defer=-60)
     r.save()
     self.assertEqual(r.notify_time,
                      n - timedelta(minutes=60) + timedelta(days=1))
예제 #10
0
    def test_add_add_participant(self):
        WechatUser(openid='abc', nickname='abcabc', subscribe=True).save()
        r = Remind(time=timezone.now(),
                   owner_id='miao',
                   event='吃饭',
                   desc='吃饭饭')
        r.save()
        r.add_participant('abc')
        r.add_participant('abc')

        self.assertEqual(r.participants, ['abc'])
예제 #11
0
 def setUp(self):
     self.request = RequestFactory().get('/')
     user = get_user_model()(openid='miao', nickname='abc')
     user.save()
     self.request.user = user
     self.r = Remind(time=timezone.now(),
                     owner_id='miao',
                     event='吃饭',
                     desc='吃饭饭',
                     done=True)
     self.r.save()
예제 #12
0
    def parse_by_rules(self, text):
        # TODO: refine me, here is an ad-hoc patch to distinguish weekday and hour
        _text = re.sub(ur'([周|星期]\w)(\d)', r'\1 \2', text, flags=re.U)
        self.words = pseg.lcut(parse_cn_number(_text), HMM=False)
        while self.has_next():
            self.parse_beginning = self.get_index()

            self.consume_repeat()

            self.consume_year_period() \
                or self.consume_month_period() \
                or self.consume_day_period()

            self.consume_weekday_period() \
                or self.consume_hour_period() \
                or self.consume_minute_period() \
                or self.consume_second_period()

            self.consume_year() \
                or self.consume_month() \
                or self.consume_day()

            self.consume_hour()

            if self.get_index() != self.parse_beginning:
                # Time found
                self.consume_word(u'准时')
                self.consume_word(u'是')
                if self.consume_word(u'提醒'):
                    self.consume_word(u'我')
                if self.current_tag() == 'v' and self.peek_next_word() == u'我':
                    self.advance(2)
                self.consume_to_end()
                try:
                    self.now += relativedelta(**self.time_delta_fields)
                    self.now = self.now.replace(**self.time_fields)
                except ValueError:
                    raise ParseError(u'/:no亲,时间或者日期超范围了')
                # Donot set event to None, since serializer will just skip None and we will have no chance to modify it
                remind = Remind(time=self.now,
                                repeat=self.repeat,
                                desc=text,
                                event=self.do_what)
                remind.reschedule()
                return remind
            else:
                self.advance()
        return None
예제 #13
0
def parse_by_wechat_api(text, **kwargs):
    """
    {
        "errcode": 0,
        "query": "提醒我上午十点开会",
        "semantic": {
            "details": {
                "answer": "",
                "context_info": {},
                "datetime": {
                    "date": "2015-12-23",
                    "date_lunar": "2015-11-13",
                    "time": "10:00:00",
                    "time_ori": "上午十点",
                    "type": "DT_ORI",
                    "week": "3"
                },
                "event": "开会",
                "hit_str": "提醒 我 上午 十点 开会 ",
                "remind_type": "0"
            },
            "intent": "SEARCH"
        },
        "type": "remind"
    }
    """
    try:
        wechat_result = wechat_client.semantic.search(
            query=text,
            category='remind',
            city='上海', # F**k, weixin always needs the city param, hard-code one.
            **kwargs
        )
    except WeChatClientException as e:
        logger.info('Failed to parse using wechat api ' + str(e))
        raise
    # wechat_result = json.loads(parse_by_wechat_api.__doc__)
    logger.debug('Semantic result from wechat, %s',
                 json.dumps(wechat_result, ensure_ascii=False))

    dt_str = '%s %s+08:00' % (
        wechat_result['semantic']['details']['datetime']['date'],
        wechat_result['semantic']['details']['datetime']['time'],
    )  # there could be nothing in details
    dt = parse_datetime(dt_str)
    return Remind(time=dt,
                  desc=wechat_result.get('query', ''),
                  event=wechat_result['semantic']['details'].get('event', ''))
예제 #14
0
    def parse_by_rules(self, text):
        self.words = pseg.lcut(parse_cn_number(text), HMM=False)
        while self.has_next():
            beginning = self.get_index()

            self.consume_repeat()

            self.consume_year_period() \
                or self.consume_month_period() \
                or self.consume_day_period()

            self.consume_weekday_period() \
                or self.consume_hour_period() \
                or self.consume_minute_period() \
                or self.consume_second_period()

            self.consume_year() \
                or self.consume_month() \
                or self.consume_day()

            self.consume_hour()

            if self.get_index() != beginning:
                # Time found
                self.consume_word(u'准时')
                if self.consume_word(u'提醒'):
                    self.consume_word(u'我')
                if self.current_tag() == 'v' and self.peek_next_word() == u'我':
                    self.advance(2)
                self.consume_to_end()
                # Donot set event to None,since serializer will just skip None and we will have no chance to modify it
                remind = Remind(time=self.now,
                                repeat=self.repeat,
                                desc=text,
                                event=self.do_what)
                remind.reschedule()
                return remind
            else:
                self.advance()
        return None
예제 #15
0
 def test_default_title(self):
     r = Remind(time=timezone.now(), owner_id='miao', desc='吃饭饭', done=True)
     r.save()
     serializer = RemindSerializer(instance=r)
     self.assertEqual(serializer.data['title'], Remind.default_title)