Пример #1
0
def test_get_user():
    bot = Minette(prepare_table=True)
    with bot.connection_provider.get_connection() as connection:
        # register user for test
        u = bot.user_store.get(
            channel="get_user_test", channel_user_id=user_id,
            connection=connection)
        u.name = "user channel"
        bot.user_store.save(u, connection)
        u_detail = bot.user_store.get(
            channel="get_user_test_detail", channel_user_id=user_id,
            connection=connection)
        u_detail.name = "user detail"
        bot.user_store.save(u_detail, connection)

        # without detail
        request = Message(
            text="hello", channel="get_user_test", channel_user_id=user_id)
        user = bot._get_user(request, connection)
        assert user.channel == "get_user_test"
        assert user.channel_user_id == user_id
        assert user.name == "user channel"

        # with detail
        bot.config.confg_parser.set("minette", "user_scope", "channel_detail")
        request = Message(
            text="hello", channel="get_user_test", channel_detail="detail",
            channel_user_id=user_id)
        user = bot._get_user(request, connection)
        assert user.channel == "get_user_test_detail"
        assert user.channel_user_id == user_id
        assert user.name == "user detail"
Пример #2
0
def test_init_args():
    # initialize arguments
    config = Config("")
    config.confg_parser.add_section("test_section")
    config.confg_parser.set("test_section", "test_key", "test_value")
    tz = timezone("Asia/Tokyo")
    logger = getLogger("test_core_logger")
    print(logger.name)
    connection_provider = CustomConnectionProvider
    context_store = CustomContextStore
    user_store = CustomUserStore
    messagelog_store = CustomMessageLogStore
    data_stores = CustomDataStores
    default_dialog_service = MyDialog
    dialog_router = MyDialogRouter
    tagger = CustomTagger
    custom_router_arg = "router_value"

    # create bot
    bot = Minette(
        config=config, timezone=tz, logger=logger,
        connection_provider=connection_provider, context_store=context_store,
        user_store=user_store, messagelog_store=messagelog_store,
        default_dialog_service=default_dialog_service,
        dialog_router=dialog_router,
        custom_router_arg=custom_router_arg,
        tagger=tagger, prepare_table=True
    )
    assert bot.config.get("test_key", section="test_section") == "test_value"
    assert bot.timezone == timezone("Asia/Tokyo")
    assert bot.logger.name == "test_core_logger"
    assert isinstance(bot.connection_provider, CustomConnectionProvider)
    assert isinstance(bot.context_store, CustomContextStore)
    assert isinstance(bot.user_store, CustomUserStore)
    assert isinstance(bot.messagelog_store, CustomMessageLogStore)
    assert bot.default_dialog_service is MyDialog
    assert isinstance(bot.dialog_router, MyDialogRouter)
    assert bot.dialog_router.custom_attr == "router_value"
    assert isinstance(bot.tagger, CustomTagger)

    # create bot with data_stores
    bot = Minette(
        config=config, timezone=tz, logger=logger,
        data_stores=data_stores,
        default_dialog_service=default_dialog_service,
        dialog_router=dialog_router,
        custom_router_arg=custom_router_arg,
        tagger=tagger, prepare_table=True
    )
    assert bot.config.get("test_key", section="test_section") == "test_value"
    assert bot.timezone == timezone("Asia/Tokyo")
    assert bot.logger.name == "test_core_logger"
    assert isinstance(bot.connection_provider, CustomConnectionProvider)
    assert isinstance(bot.context_store, CustomContextStore)
    assert isinstance(bot.user_store, CustomUserStore)
    assert isinstance(bot.messagelog_store, CustomMessageLogStore)
    assert bot.default_dialog_service is MyDialog
    assert isinstance(bot.dialog_router, MyDialogRouter)
    assert bot.dialog_router.custom_attr == "router_value"
    assert isinstance(bot.tagger, CustomTagger)
Пример #3
0
def test_chat_with_tagger_no_parse():
    bot = Minette(
        default_dialog_service=TaggerDialog,
        tagger=JanomeTagger, tagger_max_length=0)
    assert bot.tagger.max_length == 0
    res = bot.chat("今日はいい天気です。")
    assert res.messages[0].text == "今日はいい天気です。"
    words = res.messages[0].payloads[0].content
    assert words == []
Пример #4
0
def test_chat_with_tagger():
    bot = Minette(
        default_dialog_service=TaggerDialog,
        tagger=JanomeTagger)
    res = bot.chat("今日はいい天気です。")
    assert res.messages[0].text == "今日はいい天気です。"
    words = res.messages[0].payloads[0].content
    assert words[0].surface == "今日"
    assert words[1].surface == "は"
    assert words[2].surface == "いい"
    assert words[3].surface == "天気"
    assert words[4].surface == "です"
Пример #5
0
def test_chat_parse_morph_manually():
    bot = Minette(
        default_dialog_service=TaggerManuallyParseDialog,
        tagger=JanomeTagger, tagger_max_length=0)
    bot.dialog_uses(tagger=bot.tagger)
    res = bot.chat("今日はいい天気です。")
    assert res.messages[0].text == "今日はいい天気です。"
    words = res.messages[0].payloads[0].content
    assert words[0].surface == "今日"
    assert words[1].surface == "は"
    assert words[2].surface == "いい"
    assert words[3].surface == "天気"
    assert words[4].surface == "です"
Пример #6
0
def test_dialog_uses():
    class HighCostToCreate:
        pass

    class OnlyForFooDS:
        pass

    class FooFialog(DialogService):
        pass

    # run once when create bot
    hctc = HighCostToCreate()
    offds = OnlyForFooDS()

    # create bot
    bot = Minette()

    # set dependencies to dialogs
    bot.dialog_uses(
        {
            FooFialog: {"api": offds}
        },
        highcost=hctc
    )

    assert bot.dialog_router.dependencies.highcost == hctc
    assert hasattr(bot.dialog_router.dependencies, "api") is False
    assert bot.dialog_router.dependency_rules[FooFialog]["api"] == offds

    # create bot and not set dialog dependencies
    bot_no_dd = Minette()
    assert bot_no_dd.dialog_router.dependencies is None
    bot_no_dd.dialog_uses()
    assert isinstance(bot_no_dd.dialog_router.dependencies, DependencyContainer)
Пример #7
0
def test_chat_parse_morph_manually_generator():
    bot = Minette(
        default_dialog_service=TaggerManuallyParseGeneratorDialog,
        tagger=JanomeTagger, tagger_max_length=0)
    bot.dialog_uses(tagger=bot.tagger)
    res = bot.chat("今日はいい天気です。")
    assert res.messages[0].text == "今日はいい天気です。"
    assert isinstance(res.messages[0].payloads[0].content, GeneratorType)
    words = [w for w in res.messages[0].payloads[0].content]
    assert words[0].surface == "今日"
    assert words[1].surface == "は"
    assert words[2].surface == "いい"
    assert words[3].surface == "天気"
    assert words[4].surface == "です"
Пример #8
0
def test_get_context():
    bot = Minette(prepare_table=True)
    with bot.connection_provider.get_connection() as connection:
        # register context for test
        ctx = bot.context_store.get(
            channel="get_context_test", channel_user_id=user_id,
            connection=connection)
        ctx.data["unixtime"] = date_to_unixtime(now)
        bot.context_store.save(ctx, connection)
        ctx_group = bot.context_store.get(
            channel="get_context_test", channel_user_id="group_" + user_id,
            connection=connection)
        ctx_group.data["unixtime"] = date_to_unixtime(now)
        bot.context_store.save(ctx_group, connection)
        ctx_detail = bot.context_store.get(
            channel="get_context_test_detail", channel_user_id=user_id,
            connection=connection)
        ctx_detail.data["unixtime"] = date_to_unixtime(now)
        bot.context_store.save(ctx_detail, connection)

        # without detail
        request = Message(
            text="hello", channel="get_context_test", channel_user_id=user_id)
        context = bot._get_context(request, connection)
        assert context.channel == "get_context_test"
        assert context.channel_user_id == user_id
        assert context.data["unixtime"] == date_to_unixtime(now)

        # group without group
        request = Message(
            text="hello", channel="get_context_test", channel_user_id=user_id)
        request.group = Group(id="group_" + user_id)
        context = bot._get_context(request, connection)
        assert context.channel == "get_context_test"
        assert context.channel_user_id == "group_" + user_id
        assert context.data["unixtime"] == date_to_unixtime(now)

        # with detail
        bot.config.confg_parser.set(
            "minette", "context_scope", "channel_detail")
        request = Message(
            text="hello", channel="get_context_test", channel_detail="detail",
            channel_user_id=user_id)
        context = bot._get_context(request, connection)
        assert context.channel == "get_context_test_detail"
        assert context.channel_user_id == user_id
        assert context.data["unixtime"] == date_to_unixtime(now)
Пример #9
0
def test_save_user():
    bot = Minette(prepare_table=True)
    with bot.connection_provider.get_connection() as connection:
        # register user for test
        u = bot.user_store.get(
            channel="save_user_test", channel_user_id=user_id,
            connection=connection)
        u.name = "Tomori Nao"

        # save
        bot._save_user(u, connection)

        # check
        request = Message(
            text="hello", channel="save_user_test", channel_user_id=user_id)
        user = bot._get_user(request, connection)
        assert user.channel == "save_user_test"
        assert user.channel_user_id == user_id
        assert user.name == "Tomori Nao"
Пример #10
0
def test_save_context():
    bot = Minette(prepare_table=True)
    with bot.connection_provider.get_connection() as connection:
        # register context for test
        ctx = bot.context_store.get(
            channel="save_context_test", channel_user_id=user_id,
            connection=connection)
        ctx.data["unixtime"] = date_to_unixtime(now)

        # save
        ctx.topic.keep_on = True
        bot._save_context(ctx, connection)

        # check
        request = Message(
            text="hello", channel="save_context_test", channel_user_id=user_id)
        context = bot._get_context(request, connection)
        assert context.channel == "save_context_test"
        assert context.channel_user_id == user_id
        assert context.data["unixtime"] == date_to_unixtime(now)
Пример #11
0
def test_init():
    # without config
    bot = Minette()
    assert bot.config.get("timezone") == "UTC"
    assert bot.timezone == timezone("UTC")
    assert isinstance(bot.logger, Logger)
    assert bot.logger.name == "minette"
    assert isinstance(bot.connection_provider, SQLiteConnectionProvider)
    assert isinstance(bot.context_store, SQLiteContextStore)
    assert isinstance(bot.user_store, SQLiteUserStore)
    assert isinstance(bot.messagelog_store, SQLiteMessageLogStore)
    assert bot.default_dialog_service is None
    assert isinstance(bot.tagger, Tagger)
Пример #12
0
def test_init_config():
    bot = Minette(config_file="./config/test_config.ini")
    assert bot.timezone == timezone("Asia/Tokyo")
    for handler in bot.logger.handlers:
        if isinstance(handler, FileHandler):
            assert handler.baseFilename == \
                os.path.join(os.path.dirname(os.path.abspath(__file__)),
                bot.config.get("log_file"))
    assert bot.connection_provider.connection_str != ""
    assert bot.connection_provider.connection_str == \
        bot.config.get("connection_str")
    assert bot.context_store.timeout == bot.config.get("context_timeout")
    assert bot.context_store.table_name == bot.config.get("context_table")
    assert bot.user_store.table_name == bot.config.get("user_table")
    assert bot.messagelog_store.table_name == \
        bot.config.get("messagelog_table")
Пример #13
0
            return "Item closed: ✅#{} {}".format(context.data["item"].id, context.data["item"].text)
        elif context.topic.status == "item_not_found":
            return "Item not found: #{}".format(context.data["item_id"])
        elif context.topic.status == "item_listed":
            text = "Todo:"
            for item in context.data["items"]:
                text += "\n{}#{} {}".format("□ " if item.is_closed == 0 else "✅", item.id, item.text)
            return text
        elif context.topic.status == "no_items":
            return "No todo item registered"
        else:
            return "Something wrong :("


# Create an instance of Minette with TodoDialogService and SQLAlchemyStores
bot = Minette(
    default_dialog_service=TodoDialogService,
    data_stores=SQLAlchemyStores,
    connection_str="sqlite:///todo.db",
    db_echo=False)

# Create table(s) using engine
Base.metadata.create_all(bind=bot.connection_provider.engine)

# Send and receive messages
while True:
    req = input("user> ")
    res = bot.chat(req)
    for message in res.messages:
        print("minette> " + message.text)
Пример #14
0
    # Configure intent->dialog routing table
    def register_intents(self):
        self.intent_resolver = {
            # If the intent is "TranslationIntent" then use TranslationDialogService
            "TranslationIntent": TranslationDialogService,
            "EchoIntent": EchoDialogService
        }

    # Implement the intent extraction logic
    def extract_intent(self, request, context, connection):
        # Return TranslationIntent if request contains "translat"
        if "translat" in request.text.lower():
            return "TranslationIntent"

        # Return EchoIntent if request is not "ignore"
        # If "ignore", chatbot doesn't return reply message.
        elif request.text.lower() != "ignore":
            return "EchoIntent"


if __name__ == "__main__":
    # Create bot
    bot = Minette(dialog_router=MyDialogRouter)

    # Start conversation
    while True:
        req = input("user> ")
        res = bot.chat(req)
        for message in res.messages:
            print("minette> " + message.text)
Пример #15
0
def test_chat_timezone():
    bot = Minette(default_dialog_service=MyDialog, timezone=timezone("Asia/Tokyo"))
    res = bot.chat("hello")
    # bot.timezone itself is +9:19
    assert res.messages[0].timestamp.tzinfo == datetime.now(tz=bot.timezone).tzinfo
Пример #16
0
def test_chat_dialog_error():
    bot = Minette(default_dialog_service=ErrorDialog)
    res = bot.chat("hello")
    assert res.messages[0].text == "?"
Пример #17
0
def test_chat_messagelog_error():
    bot = Minette(default_dialog_service=MyDialog)
    bot.messagelog_store = None
    res = bot.chat("hello")
    assert res.messages[0].text == "res:hello"
Пример #18
0
# Custom dialog service
class DiceDialogService(DialogService):
    def process_request(self, request, context, connection):
        # Text processing using the result of Janome
        context.data["proper_nouns"] = \
            [w.surface for w in request.words if w.part_detail1 == "固有名詞"]

    def compose_response(self, request, context, connection):
        if context.data.get("proper_nouns"):
            # Echo extracted proper nouns when the request contains
            return "固有名詞あり: " + ", ".join(context.data.get("proper_nouns"))
        else:
            # Echo with analysis result
            return ", ".join(
                ["{}({})".format(w.surface, w.part) for w in request.words])


if __name__ == "__main__":
    # Create bot with Janome Tagger
    bot = Minette(
        default_dialog_service=DiceDialogService,
        tagger=JanomeTagger,
        # user_dic="/path/to/userdict"    # <= Uncomment when you use user dict
    )
    # Start conversation
    while True:
        req = input("user> ")
        res = bot.chat(req)
        for message in res.messages:
            print("minette> " + message.text)
Пример #19
0
def test_chat():
    bot = Minette(default_dialog_service=MyDialog)
    res = bot.chat("hello")
    assert res.messages[0].text == "res:hello"
Пример #20
0
def test_chat_error():
    bot = Minette(default_dialog_service=MyDialog)
    bot.connection_provider = None
    res = bot.chat("hello")
    assert res.messages == []
Пример #21
0
"""
import random
from minette import Minette, DialogService


# Custom dialog service
class DiceDialogService(DialogService):
    # Process logic and build context data
    def process_request(self, request, context, connection):
        context.data = {
            "dice1": random.randint(1, 6),
            "dice2": random.randint(1, 6)
        }

    # Compose response message using context data
    def compose_response(self, request, context, connection):
        return "Dice1:{} / Dice2:{}".format(
            str(context.data["dice1"]), str(context.data["dice2"]))


if __name__ == "__main__":
    # Create bot
    bot = Minette(default_dialog_service=DiceDialogService)
    # Start conversation
    while True:
        req = input("user> ")
        res = bot.chat(req)
        for message in res.messages:
            print("minette> " + message.text)
Пример #22
0
from minette import Minette
from minette.dialog import DialogService
from minette.tagger.mecabservice import MeCabServiceTagger
from minette.channel.line import LineAdapter
from dialog_router import MyDialogRouter
from tasks.scheduler import MyScheduler
from dialogs.specialecho import SpecialEchoDialogService
from controllers.endpoint import bp as endpoint_bp
from controllers.messagelog import bp as messagelog_bp
from controllers.liff import bp as liff_bp

# BOTのインスタンス化
bot = Minette.create(
    config_file="./minette.ini",
    dialog_router=MyDialogRouter,
    default_dialog_service=SpecialEchoDialogService,
    tagger=MeCabServiceTagger,
    # task_scheduler=MyScheduler  #タスクスケジューラーを利用するにはこの行をコメントアウト
)

# LINEアダプターの設定
line_adapter = LineAdapter(bot)

# Webアプリケーションのセットアップ
app = Flask(__name__)
app.line_adapter = line_adapter
app.register_blueprint(endpoint_bp)
app.register_blueprint(messagelog_bp)
app.register_blueprint(liff_bp)

# Webアプリケーションの起動