aboutsummaryrefslogtreecommitdiff
path: root/selenium/test.py
blob: c0a5de74297bdfaa4663a74de49df659ebf556c0 (plain)
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
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 = 'http://bank.test.taler.net'
donations = 'http://shop.test.taler.net'

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 make_donation(client):
    """Make donation at shop.test.taler.net. Assume the wallet has coins"""
    client.get(donations)
    form = client.find_element(By.TAG_NAME, "form")
    form.submit() # amount and receiver chosen
    confirm_taler = client.find_element(By.XPATH, "//form//input[@type='button']")
    confirm_taler.click() # Taler as payment option chosen
    wait = WebDriverWait(client, 10)
    confirm_pay = wait.until(EC.element_to_be_clickable((By.XPATH, "//button[@class='accept']"))) 
    confirm_pay.click()

def register(client):
    """Register a new user to the bank delaying its execution until the
    profile page is shown"""
    client.get(bank + '/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)
make_donation(client)
# client.close()