Source code for tests.end_to_end_test.test_wrong_sql_query_input

# !/usr/bin/python
# -*- coding: utf-8 -*-
# disable backslash in string because special characters need to be escaped
# pylint: disable=anomalous-backslash-in-string
"""Test Class for end to end Tests.
These Tests can only be run on Linux because it makes use of pexpect."""

import os
import platform
import tempfile
import unittest

import pexpect
from tests.end_to_end_test import end_to_end_test_helper


[docs]class WrongSQLQueryInputTest(unittest.TestCase): """Test file for wrong input."""
[docs] def testWrongSQLQueryInput(self): """Test easy file generation without errors 1. plasoscaffolder sqlite 2. What's the path to the plaso project?: tmpdir 3. What's the name of the plugin?: test 4. What's the path to your test file?: test_database/twitter_ios.db 5. Do you want to have a output example for your SQL Query? [Y/n]: n 6. Please write your SQL script for the plugin: select * from user 7. Error: no such table: user 8. Please write your SQL script for the plugin: select * from users; select * from users 9. Warning: You can only execute one statement at a time. 10. Please write your SQL script for the plugin: drop table users 11. Query has to be a single SELECT query. 12. Please write your SQL script for the plugin ['abort' to continue]: select * from users 13. The SQL query was ok. 14. Do you want to name the query parse row: Users ? [Y/n]: Y 15. Is the column a time event? updatedAt [Y/n]: Y 16. Is the column a time event? createdDate [Y/n]: Y 17. Enter (additional) timestamp events from the query [column-Name, aliasName...] or [abort]: abort 18. Does the event Users need customizing? [y/N]: N 19. Do you want to add another Query? [Y/n]: y 20. Please write your SQL script for the plugin ['abort' to continue]: abort 21. Do you want to Generate the files [Y/n]: Y """ if platform.system() in ['Linux']: with tempfile.TemporaryDirectory() as tmpdir: helper = end_to_end_test_helper.EndToEndTestHelper(tmpdir, 'test') path_answer = tmpdir expected_path = os.path.join(helper.DIR_PATH, 'ExpectedEasyGenerationFiles') command = 'python {0} sqlite'.format(helper.MAIN_PATH) child = pexpect.spawn(command) child.expect(helper.PATH_QUESTION) child.sendline(path_answer) child.expect(path_answer) child.expect(helper.NAME_QUESTION) child.sendline(helper.NAME_ANSWER) child.expect(helper.NAME_ANSWER) child.expect(helper.TESTFILE_QUESTION) child.sendline(helper.TESTFILE_ANSWER) child.expect(helper.TESTFILE_ANSWER) child.expect(helper.OUTPUT_QUESTION) child.sendline(helper.COLUMN_ANSWER_NO) child.expect(helper.COLUMN_ANSWER_NO) child.expect(helper.SQL_QUESTION) child.sendline('select * from user') child.expect('select \* from user') child.expect('Error\: no such table\: user') child.expect(helper.SQL_QUESTION) child.sendline('select * from users; select * from users') child.expect('select \* from users\; select \* from users') child.expect('Warning\: You can only execute one statement at a time\.') child.expect(helper.SQL_QUESTION) child.sendline('drop table users') child.expect('drop table users') child.expect('Query has to be a single SELECT query\.') child.expect(helper.SQL_QUESTION) child.sendline(helper.SQL_ANSWER) child.expect(helper.SQL_ANSWER_ESCAPED) child.expect(helper.SQL_ANSWER_OK) child.expect(helper.NAME_ROW_QUESTION_USERS) child.sendline(helper.NAME_ROW_ANSWER_YES) child.expect(helper.NAME_ROW_ANSWER_YES) child.expect(helper.COLUMN_QUESTION_UPDATED_AT) child.sendline(helper.COLUMN_ANSWER_YES) child.expect(helper.COLUMN_ANSWER_YES) child.expect(helper.COLUMN_QUESTION_CREATED_DATE) child.sendline(helper.COLUMN_ANSWER_YES) child.expect(helper.COLUMN_ANSWER_YES) child.expect(helper.ADDITIONAL_TIMESTAMP) child.sendline(helper.ADDITIONAL_TIMESTAMP_ABORT) child.expect(helper.ADDITIONAL_TIMESTAMP_ABORT) child.expect(helper.CUSTOM_QUESTION_USERS) child.sendline(helper.CUSTOM_ANSWER_NO) child.expect(helper.CUSTOM_ANSWER_NO) child.expect(helper.ADD_QUESTION) child.sendline(helper.ADD_ANSWER_YES) child.expect(helper.ADD_ANSWER_YES) child.expect(helper.SQL_QUESTION_WITH_ABORT) child.sendline('abort') child.expect('abort') child.expect(helper.GENERATE_QUESTION) child.sendline(helper.GENERATE_ANSWER_YES) child.expect('create.*{0}'.format(helper.formatter_path)) child.expect('create.*{0}'.format(helper.parser_path)) child.expect('create.*{0}'.format(helper.formatter_test_path)) child.expect('create.*{0}'.format(helper.parser_test_path)) child.expect('copy.*{0}'.format(helper.test_data_path)) child.expect('create.*{0}'.format(helper.parsers_init_path)) child.expect('create.*{0}'.format(helper.formatter_init_path)) formatter_init = helper.ReadFromFile(helper.formatter_init_path) formatter = helper.ReadFromFile(helper.formatter_path) formatter_test = helper.ReadFromFile(helper.formatter_test_path) parser_init = helper.ReadFromFile(helper.parsers_init_path) parser = helper.ReadFromFile(helper.parser_path) parser_test = helper.ReadFromFile(helper.parser_test_path) expected_formatter_init = helper.ReadFromFile(os.path.join( expected_path, 'formatters_init.py')) expected_formatter = helper.ReadFromFile( os.path.join(expected_path, 'formatters.py')) expected_formatter_test = helper.ReadFromFile(os.path.join( expected_path, 'formatters_test.py')) expected_parser_init = helper.ReadFromFile( os.path.join(expected_path, 'parsers_init.py')) expected_parser = helper.ReadFromFile( os.path.join(expected_path, 'parsers.py')) expected_parser_test = helper.ReadFromFile( os.path.join(expected_path, 'parsers_test.py')) self.assertEqual(formatter_init, expected_formatter_init) self.assertEqual(formatter, expected_formatter) self.assertEqual(formatter_test, expected_formatter_test) self.assertEqual(parser_init, expected_parser_init) self.assertEqual(parser, expected_parser) self.assertEqual(parser_test, expected_parser_test) else: raise NotImplementedError("test only implemented for linux platform")
if __name__ == '__main__': unittest.main()