diff options
| author | Marcello Stanisci <marcello.stanisci@inria.fr> | 2016-04-27 13:54:35 +0200 | 
|---|---|---|
| committer | Marcello Stanisci <marcello.stanisci@inria.fr> | 2016-04-27 13:54:35 +0200 | 
| commit | 320eac1675fd3c4b2de4d5dd404ecc413b9ea505 (patch) | |
| tree | bee8962d2e5ebd7dec88ce0625df2de952fa1dff /selenium | |
| parent | 90c67fc7178ad2219d37ae36d0a0b7c842de75fe (diff) | |
selenium test not in unittest
Diffstat (limited to 'selenium')
| -rw-r--r-- | selenium/test.py | 100 | ||||
| -rw-r--r-- | selenium/wallet-test.py | 118 | 
2 files changed, 100 insertions, 118 deletions
| diff --git a/selenium/test.py b/selenium/test.py new file mode 100644 index 000000000..8720c79d7 --- /dev/null +++ b/selenium/test.py @@ -0,0 +1,100 @@ +from selenium import webdriver +from selenium.webdriver.common.by import By +from selenium.webdriver.support import expected_conditions as EC +from selenium.webdriver.support.ui import WebDriverWait +import time +import logging + +logger = logging.getLogger(__name__) +bank_url = 'http://127.0.0.1:9898' + +def client_setup(): +    """Return a dict containing the driver and the extension's id""" +    co = webdriver.ChromeOptions() +    co.add_argument("load-extension=/home/marcello/wallet-webex") +    cap = webdriver.DesiredCapabilities.CHROME.copy() +    cap['loggingPrefs'] = {'driver': 'INFO', 'browser': 'INFO'} +    client = webdriver.Chrome(chrome_options=co, desired_capabilities=cap) +    client.get('https://taler.net') +    listener = """\ +        document.addEventListener('taler-id', function(evt){ +          var html = document.getElementsByTagName('html')[0]; +          html.setAttribute('data-taler-wallet-id', evt.detail.id); +        });  + +        var evt = new CustomEvent('taler-query-id'); +        document.dispatchEvent(evt); +        """ +    client.execute_script(listener) +    client.implicitly_wait(5) +    html = client.find_element(By.TAG_NAME, "html") +    return {'client': client, 'ext_id': html.get_attribute('data-taler-wallet-id')} + + +def is_error(client): +    """Return True in case of errors in the browser, False otherwise""" +    for log_type in ['browser']: +        for log in client.get_log(log_type): +            if log['level'] is 'error': +                print(log['level'] + ': ' + log['message']) +                return True +        return False + + +def register(client): +    """Register a new user to the bank delaying its execution until the +    profile page is shown""" +    client.get(bank_url + '/accounts/register') +    client.find_element(By.TAG_NAME, "form") +    register = """\ +        var form = document.getElementsByTagName('form')[0]; +        form.username.value = '%s'; +        form.password.value = 'test'; +        form.submit(); +        """ % str(int(time.time())) # need fresh username + +    client.execute_script(register) +    # need implicit wait to be set up +    button = client.find_element(By.ID, "select-exchange") +    # when button is gotten, the browser is in the profile page +    # so the function can return +    if not is_error(client): +        logger.info('correctly registered at bank') +    else: +        logger.error('User not registered at bank') + + +def withdraw(client): +    """Register and withdraw (1) KUDOS for a fresh user""" +    register(client) +    # trigger withdrawal button +    button = client.find_element(By.ID, "select-exchange") +    button.click() +    location = client.execute_script("return document.location.href") +    client.get(location) +    # Confirm xchg +    wait = WebDriverWait(client, 10) +    button = wait.until(EC.element_to_be_clickable((By.XPATH, "//button[1]"))) +    # This click returns the captcha page (put wait?) +    button.click() +    answer = client.find_element(By.XPATH, "//input[@name='pin_0']") +    question = client.find_element(By.XPATH, "//span[@class='captcha-question']/div") +    questionTok = question.text.split() +    op1 = int(questionTok[2]) +    op2 = int(questionTok[4]) +    res = {'+': op1 + op2, '-': op1 - op2, u'\u00d7': op1 * op2} +    answer.send_keys(res[questionTok[3]]) +    form = client.find_element(By.TAG_NAME, "form") +    form.submit() +    # check outcome +    msg_succ = client.find_element(By.CLASS_NAME, "informational-ok") +    if not msg_succ: +        logger.error('Error in withdrawing') +    else: logger.info('Withdrawal successful') + + + +ret = client_setup() +client = ret['client'] +withdraw(client) +client.close() diff --git a/selenium/wallet-test.py b/selenium/wallet-test.py deleted file mode 100644 index 1e4410c11..000000000 --- a/selenium/wallet-test.py +++ /dev/null @@ -1,118 +0,0 @@ -from selenium import webdriver -from selenium.webdriver.common.by import By -from selenium.webdriver.support import expected_conditions as EC -from selenium.webdriver.support.ui import WebDriverWait -import time -import logging -import unittest -import json - - -logger = logging.getLogger(__name__) - -def client_setup(): -    """Return a Chrome browser the extension's id""" -    co = webdriver.ChromeOptions() -    co.add_argument("load-extension=/home/marcello/wallet-webex") -    cap = webdriver.DesiredCapabilities.CHROME.copy() -    cap['loggingPrefs'] = {'driver': 'INFO', 'browser': 'INFO'} -    client = webdriver.Chrome(chrome_options=co, desired_capabilities=cap) -    client.get('https://taler.net') -    listener = """\ -        document.addEventListener('taler-id', function(evt){ -          var html = document.getElementsByTagName('html')[0]; -          html.setAttribute('data-taler-wallet-id', evt.detail.id); -        });  - -        var evt = new CustomEvent('taler-query-id'); -        document.dispatchEvent(evt); -        """ -    client.execute_script(listener) -    client.implicitly_wait(5) -    html = client.find_element(By.TAG_NAME, "html") -    return {'client': client, 'ext_id': html.get_attribute('data-taler-wallet-id')} - - -def is_error(client): -    """In case of errors in the browser, print them and return True""" -    for log_type in ['browser']: -        for log in client.get_log(log_type): -            if log['level'] is 'error': -                print(log['level'] + ': ' + log['message']) -                return True -        return False - - -# class PopupTestCase(unittest.TestCase): -#     """Test wallet's popups""" -#     def setUp(self): -#         ret = client_setup() -#         self.client = ret['client'] -#         self.ext_id = ret['ext_id'] -#  -#     def tearDown(self): -#         self.client.close() -#  -#     def test_popup(self): -#         # keeping only 'balance' to get tests faster. To be -#         # extended with 'history' and 'debug' -#         labels = ['balance'] -#         for l in labels: -#             self.client.get('chrome-extension://' + self.ext_id + '/popup/popup.html#/' + l) -#         self.assertFalse(is_error(self.client)) - -class BankTestCase(unittest.TestCase): -    """Test withdrawal (after registering a new user)""" -    def setUp(self): -        ret = client_setup() -        self.client = ret['client'] -        self.ext_id = ret['ext_id'] - -    def tearDown(self): -        pass -        # self.client.close() -     - -    def test_withdrawal(self): -        bank_url = 'http://127.0.0.1:9898' -        self.client.get(bank_url + '/accounts/register') -        self.client.find_element(By.TAG_NAME, "form") -        register = """\ -            var form = document.getElementsByTagName('form')[0]; -            form.username.value = '%s'; -            form.password.value = 'test'; -            form.submit(); -            """ % str(int(time.time())) # need fresh username - -        self.client.execute_script(register) -        self.assertFalse(is_error(self.client)) -        wait = WebDriverWait(self.client, 10) -        button = self.client.find_element(By.ID, "select-exchange") -        button = wait.until(EC.element_to_be_clickable((By.ID, "select-exchange"))) -        # click to confirm the amount to withdraw -        button.click() -        # Note: this further 'get()' seems needed to get the in-wallet page loaded -        location = self.client.execute_script("return document.location.href") -        self.client.get(location) -        # Confirm xchg -        button = wait.until(EC.element_to_be_clickable((By.XPATH, "//button[1]"))) -        # This click returns the captcha page (put wait?) -        button.click() -        # Note: a wait for getting the inputElem below could be needed -        inputElem = self.client.find_element(By.XPATH, "//input[@name='pin_0']") -        self.assertIsNotNone(inputElem) -        # get the question -        question = self.client.find_element(By.XPATH, "//span[@class='captcha-question']/div") -        questionTok = question.text.split() -        op1 = int(questionTok[2]) -        op2 = int(questionTok[4]) -        res = {'+': op1 + op2, '-': op1 - op2, u'\u00d7': op1 * op2} -        inputElem.send_keys(res[questionTok[3]]) -        form = self.client.find_element(By.TAG_NAME, "form") -        form.submit() -        # check if successful message exists -        msg_succ = self.client.find_element(By.CLASS_NAME, "informational-ok") -        self.assertNotNone(msg_succ) - -if __name__ == '__main__': -    unittest.main() | 
