forked from Chintan2108/CHEERBOT-Your-Emotional-Companion
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_broize.py
82 lines (60 loc) · 2.51 KB
/
test_broize.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
# -*- coding: utf-8 -*-
import random
import pytest
random.seed(0)
from broize import *
def test_random_utterance():
"""An utterance which is unparsable should return one of the random responses"""
sent = "abcd" # Something unparseable
resp = broback(sent)
assert resp == NONE_RESPONSES[-2]
def test_basic_greetings():
"""The bot should respond sensibly to common greeting words"""
sent = "hello"
resp = broback(sent)
assert resp == GREETING_RESPONSES[1]
def test_contains_reference_to_user():
"""An utterance where the user mentions themselves generally should specifically return a phrase starting with 'You'"""
sent = "I went to dinner"
resp = broback(sent)
assert resp.startswith("You ")
def test_negs_user():
"""An utterance where the user says 'I am' <something> should specifically tell them they aren't that thing"""
sent = "I am good at Python programming"
resp = broback(sent)
assert resp.startswith("You aren't really")
sent = "I'm good at Python programming"
resp = broback(sent)
assert resp.startswith("You aren't really")
sent = "i'm good at Python programming"
resp = broback(sent)
assert resp.startswith("You aren't really")
def test_contains_reference_to_bot():
"""An utterance where the user directs something at the bot itself should return a canned response"""
sent = "You are lame"
resp = broback(sent)
assert 'lame' in resp
def test_reuses_subject():
"""If the user tells us about some kind of subject, we should mention it in our response"""
sent = "I am a capable programmer"
resp = broback(sent)
assert "programmer" in resp
def test_strip_offensive_words():
"""Don't allow the bot to respond with anything obviously offensive"""
# To avoid including an offensive word in the test set, add a harmless word temporarily
from config import FILTER_WORDS
FILTER_WORDS.add('snakeperson')
sent = "I am a snakeperson"
with pytest.raises(UnacceptableUtteranceException):
broback(sent)
def test_strip_punctuation():
"""Removing most punctuation is one way to ensure that the bot doesn't include hashtags or @-signs, which are potential vectors for harrassment"""
sent = "I am a #snakeperson"
with pytest.raises(UnacceptableUtteranceException):
broback(sent)
sent = "@you are funny"
with pytest.raises(UnacceptableUtteranceException):
broback(sent)
def test_unicode():
"""Bros love internationalization"""
broback(u"☃") # Unicode snowman