2019-06-24 15:17:41 +00:00
|
|
|
import os
|
2019-09-03 21:54:23 +00:00
|
|
|
import random
|
2019-05-20 20:23:39 +00:00
|
|
|
import inspect
|
2019-03-01 17:30:53 +00:00
|
|
|
import asyncio
|
|
|
|
|
2019-07-16 18:46:08 +00:00
|
|
|
import pytest
|
2019-02-28 00:55:04 +00:00
|
|
|
import requests
|
|
|
|
|
2019-05-20 20:03:19 +00:00
|
|
|
from python3_anticaptcha import (
|
|
|
|
NoCaptchaTaskProxyless,
|
|
|
|
AntiCaptchaControl,
|
|
|
|
CustomCaptchaTask,
|
2019-07-16 18:48:28 +00:00
|
|
|
ReCaptchaV3TaskProxyless,
|
2019-05-20 20:03:19 +00:00
|
|
|
)
|
2019-07-16 18:48:28 +00:00
|
|
|
|
2019-08-20 13:02:23 +00:00
|
|
|
# 1. `export anticaptcha_key=274832f8168a36019895a1e1174777c0`
|
2019-02-28 00:55:04 +00:00
|
|
|
|
2019-07-16 18:48:28 +00:00
|
|
|
|
2019-02-28 00:55:04 +00:00
|
|
|
class TestAntiCaptcha(object):
|
2019-09-03 21:54:23 +00:00
|
|
|
WRONG_QUEUE_ID = WRONG_TASK_ID = -1
|
|
|
|
|
2019-02-28 00:55:04 +00:00
|
|
|
def setup_class(self):
|
2019-07-16 18:48:28 +00:00
|
|
|
self.anticaptcha_key_fail = os.getenv("anticaptcha_key")[:5]
|
|
|
|
self.anticaptcha_key_true = os.getenv("anticaptcha_key")
|
2019-09-03 21:54:23 +00:00
|
|
|
self.server_ip = "85.255.8.26"
|
2019-02-28 00:55:04 +00:00
|
|
|
|
2019-03-04 20:30:15 +00:00
|
|
|
# CallBack
|
2019-02-28 00:55:04 +00:00
|
|
|
def test_callback_server(self):
|
|
|
|
# test server alive
|
2019-05-20 20:03:19 +00:00
|
|
|
response = requests.get(f"http://{self.server_ip}:8001/ping")
|
2019-02-28 00:55:04 +00:00
|
|
|
assert response.status_code == 200
|
|
|
|
# try register new queue
|
2019-05-20 20:03:19 +00:00
|
|
|
response = requests.post(
|
|
|
|
f"http://{self.server_ip}:8001/register_key",
|
|
|
|
json={"key": "fwefefefopewofkewopfkop", "vhost": "anticaptcha_vhost"},
|
|
|
|
)
|
2019-02-28 00:55:04 +00:00
|
|
|
assert response.status_code == 200
|
|
|
|
|
2019-05-20 20:23:39 +00:00
|
|
|
def test_customcatpcha_params(self):
|
|
|
|
default_init_params = [
|
|
|
|
"self",
|
|
|
|
"anticaptcha_key",
|
|
|
|
"sleep_time",
|
|
|
|
"assignment",
|
|
|
|
"forms",
|
|
|
|
"callbackUrl",
|
|
|
|
]
|
|
|
|
default_handler_params = ["self", "imageUrl"]
|
|
|
|
# get customcaptcha init and captcha_handler params
|
|
|
|
aioinit_params = inspect.getfullargspec(
|
|
|
|
CustomCaptchaTask.aioCustomCaptchaTask.__init__
|
|
|
|
)
|
|
|
|
aiohandler_params = inspect.getfullargspec(
|
|
|
|
CustomCaptchaTask.aioCustomCaptchaTask.captcha_handler
|
|
|
|
)
|
|
|
|
|
|
|
|
# get customcaptcha init and captcha_handler params
|
|
|
|
init_params = inspect.getfullargspec(
|
|
|
|
CustomCaptchaTask.CustomCaptchaTask.__init__
|
|
|
|
)
|
|
|
|
handler_params = inspect.getfullargspec(
|
|
|
|
CustomCaptchaTask.CustomCaptchaTask.captcha_handler
|
|
|
|
)
|
|
|
|
# check aio module params
|
|
|
|
assert default_init_params == aioinit_params[0]
|
|
|
|
assert default_handler_params == aiohandler_params[0]
|
|
|
|
# check sync module params
|
|
|
|
assert default_init_params == init_params[0]
|
|
|
|
assert default_handler_params == handler_params[0]
|
|
|
|
|
2019-06-24 15:17:41 +00:00
|
|
|
def test_fail_customcaptcha(self):
|
2019-05-20 20:03:19 +00:00
|
|
|
customcaptcha = CustomCaptchaTask.CustomCaptchaTask(
|
2019-06-24 15:17:41 +00:00
|
|
|
anticaptcha_key=self.anticaptcha_key_fail,
|
2019-05-20 20:23:39 +00:00
|
|
|
sleep_time=10,
|
|
|
|
assignment="Smth interesting",
|
2019-05-20 20:03:19 +00:00
|
|
|
)
|
|
|
|
# check response type
|
2019-07-16 18:48:28 +00:00
|
|
|
assert type(customcaptcha) is CustomCaptchaTask.CustomCaptchaTask
|
2019-05-20 20:03:19 +00:00
|
|
|
|
|
|
|
response = customcaptcha.captcha_handler(
|
2019-05-20 20:23:39 +00:00
|
|
|
imageUrl=self.server_ip + "/static/image/common_image_example/088636.png"
|
2019-05-20 20:03:19 +00:00
|
|
|
)
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
|
|
|
|
@asyncio.coroutine
|
2019-06-24 15:17:41 +00:00
|
|
|
def test_fail_aiocustomcaptcha(self):
|
2019-05-20 20:03:19 +00:00
|
|
|
customcaptcha = CustomCaptchaTask.aioCustomCaptchaTask(
|
2019-06-24 15:17:41 +00:00
|
|
|
anticaptcha_key=self.anticaptcha_key_fail,
|
2019-05-20 20:23:39 +00:00
|
|
|
sleep_time=10,
|
|
|
|
assignment="Smth interesting",
|
2019-05-20 20:03:19 +00:00
|
|
|
)
|
|
|
|
# check response type
|
2019-07-16 18:48:28 +00:00
|
|
|
assert type(customcaptcha) is CustomCaptchaTask.aioCustomCaptchaTask
|
2019-05-20 20:03:19 +00:00
|
|
|
|
|
|
|
response = yield customcaptcha.captcha_handler(
|
2019-05-20 20:23:39 +00:00
|
|
|
imageUrl=self.server_ip + "/static/image/common_image_example/088636.png"
|
2019-05-20 20:03:19 +00:00
|
|
|
)
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
|
2019-05-20 20:23:39 +00:00
|
|
|
def test_nocaptcha_params(self):
|
|
|
|
default_init_params = ["self", "anticaptcha_key", "sleep_time", "callbackUrl"]
|
|
|
|
default_handler_params = ["self", "websiteURL", "websiteKey"]
|
|
|
|
# get customcaptcha init and captcha_handler params
|
|
|
|
aioinit_params = inspect.getfullargspec(
|
|
|
|
NoCaptchaTaskProxyless.aioNoCaptchaTaskProxyless.__init__
|
|
|
|
)
|
|
|
|
aiohandler_params = inspect.getfullargspec(
|
|
|
|
NoCaptchaTaskProxyless.aioNoCaptchaTaskProxyless.captcha_handler
|
|
|
|
)
|
|
|
|
|
|
|
|
# get customcaptcha init and captcha_handler params
|
|
|
|
init_params = inspect.getfullargspec(
|
|
|
|
NoCaptchaTaskProxyless.NoCaptchaTaskProxyless.__init__
|
|
|
|
)
|
|
|
|
handler_params = inspect.getfullargspec(
|
|
|
|
NoCaptchaTaskProxyless.NoCaptchaTaskProxyless.captcha_handler
|
|
|
|
)
|
|
|
|
# check aio module params
|
|
|
|
assert default_init_params == aioinit_params[0]
|
|
|
|
assert default_handler_params == aiohandler_params[0]
|
|
|
|
# check sync module params
|
|
|
|
assert default_init_params == init_params[0]
|
|
|
|
assert default_handler_params == handler_params[0]
|
|
|
|
|
2019-06-24 15:17:41 +00:00
|
|
|
def test_fail_nocaptcha_proxyless(self):
|
2019-05-20 20:03:19 +00:00
|
|
|
nocaptcha = NoCaptchaTaskProxyless.NoCaptchaTaskProxyless(
|
2019-06-24 15:17:41 +00:00
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
2019-05-20 20:03:19 +00:00
|
|
|
)
|
2019-02-28 00:55:04 +00:00
|
|
|
# check response type
|
2019-07-16 18:48:28 +00:00
|
|
|
assert type(nocaptcha) is NoCaptchaTaskProxyless.NoCaptchaTaskProxyless
|
2019-02-28 00:55:04 +00:00
|
|
|
|
|
|
|
response = nocaptcha.captcha_handler(
|
2019-05-20 20:03:19 +00:00
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
)
|
2019-02-28 00:55:04 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-05-20 20:03:19 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
2019-06-24 15:17:41 +00:00
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-03-01 17:30:53 +00:00
|
|
|
|
2019-06-24 15:17:41 +00:00
|
|
|
def test_fail_nocaptcha_proxyless_context(self):
|
2019-05-20 20:03:19 +00:00
|
|
|
with NoCaptchaTaskProxyless.NoCaptchaTaskProxyless(
|
2019-06-24 15:17:41 +00:00
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
2019-05-20 20:03:19 +00:00
|
|
|
) as nocaptcha:
|
|
|
|
|
2019-03-01 17:30:53 +00:00
|
|
|
# check response type
|
2019-07-16 18:48:28 +00:00
|
|
|
assert type(nocaptcha) is NoCaptchaTaskProxyless.NoCaptchaTaskProxyless
|
2019-03-01 17:30:53 +00:00
|
|
|
|
|
|
|
response = nocaptcha.captcha_handler(
|
2019-05-20 20:03:19 +00:00
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
)
|
2019-03-01 17:30:53 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-05-20 20:03:19 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
2019-06-24 15:17:41 +00:00
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-03-01 17:30:53 +00:00
|
|
|
|
|
|
|
@asyncio.coroutine
|
2019-06-24 15:17:41 +00:00
|
|
|
def test_fail_aionocaptcha_proxyless(self):
|
2019-05-20 20:03:19 +00:00
|
|
|
nocaptcha = NoCaptchaTaskProxyless.aioNoCaptchaTaskProxyless(
|
2019-06-24 15:17:41 +00:00
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
2019-05-20 20:03:19 +00:00
|
|
|
)
|
2019-03-01 17:30:53 +00:00
|
|
|
# check response type
|
2019-07-16 18:48:28 +00:00
|
|
|
assert type(nocaptcha) is NoCaptchaTaskProxyless.NoCaptchaTaskProxyless
|
2019-03-01 17:30:53 +00:00
|
|
|
|
|
|
|
response = yield nocaptcha.captcha_handler(
|
2019-05-20 20:03:19 +00:00
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
)
|
2019-03-01 17:30:53 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-05-20 20:03:19 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
2019-06-24 15:17:41 +00:00
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-03-01 17:30:53 +00:00
|
|
|
|
|
|
|
@asyncio.coroutine
|
2019-06-24 15:17:41 +00:00
|
|
|
def test_fail_aionocaptcha_proxyless_context(self):
|
2019-05-20 20:03:19 +00:00
|
|
|
with NoCaptchaTaskProxyless.aioNoCaptchaTaskProxyless(
|
2019-06-24 15:17:41 +00:00
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
2019-05-20 20:03:19 +00:00
|
|
|
) as nocaptcha:
|
2019-03-01 17:30:53 +00:00
|
|
|
# check response type
|
2019-07-16 18:48:28 +00:00
|
|
|
assert type(nocaptcha) is NoCaptchaTaskProxyless.NoCaptchaTaskProxyless
|
2019-03-01 17:30:53 +00:00
|
|
|
|
|
|
|
response = yield nocaptcha.captcha_handler(
|
2019-05-20 20:03:19 +00:00
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
)
|
2019-03-01 17:30:53 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-05-20 20:03:19 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
2019-06-24 15:17:41 +00:00
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-03-01 17:30:53 +00:00
|
|
|
|
2019-07-16 18:46:08 +00:00
|
|
|
def test_recaptcha_v3_params(self):
|
|
|
|
default_init_params = ["self", "anticaptcha_key", "sleep_time", "callbackUrl"]
|
2019-07-16 18:48:28 +00:00
|
|
|
default_handler_params = [
|
|
|
|
"self",
|
|
|
|
"websiteURL",
|
|
|
|
"websiteKey",
|
|
|
|
"minScore",
|
|
|
|
"pageAction",
|
|
|
|
]
|
2019-07-16 18:46:08 +00:00
|
|
|
# get customcaptcha init and captcha_handler params
|
|
|
|
aioinit_params = inspect.getfullargspec(
|
|
|
|
ReCaptchaV3TaskProxyless.aioReCaptchaV3TaskProxyless.__init__
|
|
|
|
)
|
|
|
|
aiohandler_params = inspect.getfullargspec(
|
|
|
|
ReCaptchaV3TaskProxyless.aioReCaptchaV3TaskProxyless.captcha_handler
|
|
|
|
)
|
|
|
|
|
|
|
|
# get customcaptcha init and captcha_handler params
|
|
|
|
init_params = inspect.getfullargspec(
|
|
|
|
ReCaptchaV3TaskProxyless.ReCaptchaV3TaskProxyless.__init__
|
|
|
|
)
|
|
|
|
handler_params = inspect.getfullargspec(
|
|
|
|
ReCaptchaV3TaskProxyless.ReCaptchaV3TaskProxyless.captcha_handler
|
|
|
|
)
|
|
|
|
# check aio module params
|
|
|
|
assert default_init_params == aioinit_params[0]
|
|
|
|
assert default_handler_params == aiohandler_params[0]
|
|
|
|
# check sync module params
|
|
|
|
assert default_init_params == init_params[0]
|
|
|
|
assert default_handler_params == handler_params[0]
|
|
|
|
|
|
|
|
def test_fail_recaptcha_v3_proxyless(self):
|
|
|
|
recaptcha = ReCaptchaV3TaskProxyless.ReCaptchaV3TaskProxyless(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
)
|
|
|
|
# check response type
|
2019-07-16 18:48:28 +00:00
|
|
|
assert type(recaptcha) is ReCaptchaV3TaskProxyless.ReCaptchaV3TaskProxyless
|
2019-07-16 18:46:08 +00:00
|
|
|
|
|
|
|
response = recaptcha.captcha_handler(
|
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
minScore=0.3,
|
2019-07-16 18:48:28 +00:00
|
|
|
pageAction="login_test",
|
2019-07-16 18:46:08 +00:00
|
|
|
)
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-07-16 18:46:08 +00:00
|
|
|
|
|
|
|
with pytest.raises(ValueError):
|
|
|
|
assert recaptcha.captcha_handler(
|
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
minScore=0.1,
|
2019-07-16 18:48:28 +00:00
|
|
|
pageAction="login_test",
|
2019-07-16 18:46:08 +00:00
|
|
|
)
|
|
|
|
|
2019-08-25 23:44:10 +00:00
|
|
|
def test_true_recaptcha_v3_proxyless(self):
|
|
|
|
recaptcha = ReCaptchaV3TaskProxyless.ReCaptchaV3TaskProxyless(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_true
|
|
|
|
)
|
|
|
|
# check response type
|
|
|
|
assert type(recaptcha) is ReCaptchaV3TaskProxyless.ReCaptchaV3TaskProxyless
|
|
|
|
|
|
|
|
response = recaptcha.captcha_handler(
|
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
minScore=0.3,
|
|
|
|
pageAction="login_test",
|
|
|
|
)
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-09-03 21:54:23 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription", "taskId"] == list(response.keys())
|
2019-08-25 23:44:10 +00:00
|
|
|
# check error code
|
2019-09-03 21:54:23 +00:00
|
|
|
# TODO change to `0`
|
|
|
|
assert response["errorId"] == 31
|
2019-08-25 23:44:10 +00:00
|
|
|
|
2019-07-16 18:46:08 +00:00
|
|
|
def test_fail_recaptcha_v3_proxyless_context(self):
|
|
|
|
with ReCaptchaV3TaskProxyless.ReCaptchaV3TaskProxyless(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
) as recaptcha:
|
|
|
|
|
|
|
|
# check response type
|
2019-07-16 18:48:28 +00:00
|
|
|
assert type(recaptcha) is ReCaptchaV3TaskProxyless.ReCaptchaV3TaskProxyless
|
2019-07-16 18:46:08 +00:00
|
|
|
|
|
|
|
response = recaptcha.captcha_handler(
|
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
minScore=0.3,
|
2019-07-16 18:48:28 +00:00
|
|
|
pageAction="login_test",
|
2019-07-16 18:46:08 +00:00
|
|
|
)
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-07-16 18:46:08 +00:00
|
|
|
|
|
|
|
with ReCaptchaV3TaskProxyless.ReCaptchaV3TaskProxyless(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
) as recaptcha:
|
|
|
|
with pytest.raises(ValueError):
|
|
|
|
assert recaptcha.captcha_handler(
|
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
minScore=0.1,
|
2019-07-16 18:48:28 +00:00
|
|
|
pageAction="login_test",
|
2019-07-16 18:46:08 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
@asyncio.coroutine
|
|
|
|
def test_fail_aiorecaptcha_v3_proxyless(self):
|
|
|
|
recaptcha = ReCaptchaV3TaskProxyless.aioReCaptchaV3TaskProxyless(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
)
|
|
|
|
# check response type
|
2019-07-16 18:48:28 +00:00
|
|
|
assert type(recaptcha) is ReCaptchaV3TaskProxyless.aioReCaptchaV3TaskProxyless
|
2019-07-16 18:46:08 +00:00
|
|
|
|
|
|
|
response = yield recaptcha.captcha_handler(
|
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
minScore=0.3,
|
2019-07-16 18:48:28 +00:00
|
|
|
pageAction="login_test",
|
2019-07-16 18:46:08 +00:00
|
|
|
)
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-07-16 18:46:08 +00:00
|
|
|
|
|
|
|
with pytest.raises(ValueError):
|
|
|
|
assert recaptcha.captcha_handler(
|
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
minScore=0.1,
|
2019-07-16 18:48:28 +00:00
|
|
|
pageAction="login_test",
|
2019-07-16 18:46:08 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
@asyncio.coroutine
|
|
|
|
def test_fail_aiorecaptcha_v3_proxyless_context(self):
|
|
|
|
with ReCaptchaV3TaskProxyless.aioReCaptchaV3TaskProxyless(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
) as recaptcha:
|
|
|
|
# check response type
|
|
|
|
assert (
|
2019-07-16 18:48:28 +00:00
|
|
|
type(recaptcha) is ReCaptchaV3TaskProxyless.aioReCaptchaV3TaskProxyless
|
2019-07-16 18:46:08 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
response = yield recaptcha.captcha_handler(
|
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
minScore=0.3,
|
2019-07-16 18:48:28 +00:00
|
|
|
pageAction="login_test",
|
2019-07-16 18:46:08 +00:00
|
|
|
)
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-07-16 18:46:08 +00:00
|
|
|
|
|
|
|
with ReCaptchaV3TaskProxyless.aioReCaptchaV3TaskProxyless(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
) as recaptcha:
|
|
|
|
with pytest.raises(ValueError):
|
|
|
|
assert recaptcha.captcha_handler(
|
|
|
|
websiteURL="https://www.google.com/recaptcha/api2/demo",
|
|
|
|
websiteKey="6Le-wvkSAAAAAPBMRTvw0Q4Muexq9bi0DJwx_mJ-",
|
|
|
|
minScore=0.1,
|
2019-07-16 18:48:28 +00:00
|
|
|
pageAction="login_test",
|
2019-07-16 18:46:08 +00:00
|
|
|
)
|
|
|
|
|
2019-08-20 13:02:23 +00:00
|
|
|
"""
|
|
|
|
Control
|
|
|
|
"""
|
|
|
|
|
|
|
|
def test_control_type(self):
|
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.AntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
)
|
|
|
|
# check response type
|
|
|
|
assert type(result) is AntiCaptchaControl.AntiCaptchaControl
|
|
|
|
|
2019-05-20 20:23:39 +00:00
|
|
|
def test_control_params(self):
|
|
|
|
default_init_params = ["self", "anticaptcha_key"]
|
|
|
|
default_balance_params = ["self"]
|
2019-08-21 01:34:29 +00:00
|
|
|
default_complaint_params = ["self", "reported_id", "captcha_type"]
|
2019-05-20 20:23:39 +00:00
|
|
|
default_queue_status_params = ["self", "queue_id"]
|
|
|
|
# get customcaptcha init and other params
|
|
|
|
aioinit_params = inspect.getfullargspec(
|
|
|
|
AntiCaptchaControl.aioAntiCaptchaControl.__init__
|
|
|
|
)
|
|
|
|
aiobalance_params = inspect.getfullargspec(
|
|
|
|
AntiCaptchaControl.aioAntiCaptchaControl.get_balance
|
|
|
|
)
|
|
|
|
aiocomplaint_params = inspect.getfullargspec(
|
|
|
|
AntiCaptchaControl.aioAntiCaptchaControl.complaint_on_result
|
|
|
|
)
|
|
|
|
aioqueue_status_params = inspect.getfullargspec(
|
|
|
|
AntiCaptchaControl.aioAntiCaptchaControl.get_queue_status
|
|
|
|
)
|
|
|
|
|
|
|
|
# get customcaptcha init and other params
|
|
|
|
init_params = inspect.getfullargspec(
|
|
|
|
AntiCaptchaControl.AntiCaptchaControl.__init__
|
|
|
|
)
|
|
|
|
balance_params = inspect.getfullargspec(
|
|
|
|
AntiCaptchaControl.AntiCaptchaControl.get_balance
|
|
|
|
)
|
|
|
|
complaint_params = inspect.getfullargspec(
|
|
|
|
AntiCaptchaControl.AntiCaptchaControl.complaint_on_result
|
|
|
|
)
|
|
|
|
queue_status_params = inspect.getfullargspec(
|
|
|
|
AntiCaptchaControl.AntiCaptchaControl.get_queue_status
|
|
|
|
)
|
|
|
|
# check aio module params
|
|
|
|
assert default_init_params == aioinit_params[0]
|
|
|
|
assert default_balance_params == aiobalance_params[0]
|
|
|
|
assert default_complaint_params == aiocomplaint_params[0]
|
|
|
|
assert default_queue_status_params == aioqueue_status_params[0]
|
|
|
|
# check sync module params
|
|
|
|
assert default_init_params == init_params[0]
|
|
|
|
assert default_balance_params == balance_params[0]
|
|
|
|
assert default_complaint_params == complaint_params[0]
|
|
|
|
assert default_queue_status_params == queue_status_params[0]
|
|
|
|
|
2019-09-03 21:54:23 +00:00
|
|
|
# AntiCaptcha Control
|
|
|
|
def test_fail_queue_status(self):
|
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.AntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
)
|
|
|
|
q_id = self.WRONG_QUEUE_ID
|
|
|
|
|
|
|
|
with pytest.raises(ValueError):
|
|
|
|
# get queue status
|
|
|
|
assert result.get_queue_status(queue_id=q_id)
|
|
|
|
|
|
|
|
# AntiCaptcha Control
|
|
|
|
def test_true_queue_status(self):
|
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.AntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_true
|
|
|
|
)
|
|
|
|
q_id = random.choice(AntiCaptchaControl.queue_ids)
|
|
|
|
for q_id in AntiCaptchaControl.queue_ids:
|
|
|
|
# get queue status
|
|
|
|
response = result.get_queue_status(queue_id=q_id)
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ['waiting', 'load', 'bid', 'speed', 'total'] == list(response.keys())
|
|
|
|
|
2019-03-01 17:30:53 +00:00
|
|
|
# AntiCaptcha Control
|
2019-08-20 13:02:23 +00:00
|
|
|
def test_fail_balance(self):
|
2019-03-01 17:30:53 +00:00
|
|
|
# prepare client
|
2019-05-20 20:03:19 +00:00
|
|
|
result = AntiCaptchaControl.AntiCaptchaControl(
|
2019-06-24 15:17:41 +00:00
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
2019-05-20 20:03:19 +00:00
|
|
|
)
|
2019-08-20 13:02:23 +00:00
|
|
|
# get balance
|
|
|
|
response = result.get_balance()
|
2019-03-01 17:30:53 +00:00
|
|
|
# check response type
|
2019-08-20 13:02:23 +00:00
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 1
|
2019-05-20 20:03:19 +00:00
|
|
|
|
2019-08-20 13:02:23 +00:00
|
|
|
# AntiCaptcha Control
|
|
|
|
def test_fail_app_stats(self):
|
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.AntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
)
|
2019-03-01 17:30:53 +00:00
|
|
|
# get balance
|
2019-08-20 13:02:23 +00:00
|
|
|
response = result.get_app_stats(softId=867)
|
2019-03-01 17:30:53 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-05-20 20:03:19 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
2019-06-24 15:17:41 +00:00
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-03-01 17:30:53 +00:00
|
|
|
|
2019-08-20 13:02:23 +00:00
|
|
|
with pytest.raises(ValueError):
|
2019-08-20 14:56:52 +00:00
|
|
|
assert result.get_app_stats(softId=867, mode="filure")
|
2019-08-20 13:02:23 +00:00
|
|
|
|
|
|
|
# AntiCaptcha Control
|
|
|
|
def test_fail_complaint_on_result(self):
|
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.AntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
)
|
2019-03-01 17:30:53 +00:00
|
|
|
# complaint on result
|
2019-09-03 21:54:23 +00:00
|
|
|
response = result.complaint_on_result(reported_id=self.WRONG_TASK_ID)
|
2019-03-01 17:30:53 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-05-20 20:03:19 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
2019-06-24 15:17:41 +00:00
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-06-24 15:17:41 +00:00
|
|
|
|
2019-08-21 01:34:29 +00:00
|
|
|
with pytest.raises(ValueError):
|
2019-08-21 01:36:40 +00:00
|
|
|
assert result.complaint_on_result(
|
2019-09-03 21:54:23 +00:00
|
|
|
reported_id=self.WRONG_TASK_ID, captcha_type="not_image"
|
2019-08-21 01:36:40 +00:00
|
|
|
)
|
2019-08-21 01:34:29 +00:00
|
|
|
|
2019-06-24 15:17:41 +00:00
|
|
|
# AntiCaptcha Control
|
2019-08-20 13:02:23 +00:00
|
|
|
def test_true_balance(self):
|
2019-06-24 15:17:41 +00:00
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.AntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_true
|
|
|
|
)
|
|
|
|
# get balance
|
|
|
|
response = result.get_balance()
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "balance"] == list(response.keys())
|
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 0
|
2019-06-24 15:17:41 +00:00
|
|
|
|
2019-08-20 13:02:23 +00:00
|
|
|
# AntiCaptcha Control
|
|
|
|
def test_true_complaint_on_result(self):
|
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.AntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_true
|
|
|
|
)
|
2019-06-24 15:17:41 +00:00
|
|
|
# complaint on result
|
2019-09-03 21:54:23 +00:00
|
|
|
response = result.complaint_on_result(reported_id=self.WRONG_TASK_ID, captcha_type="image")
|
2019-08-21 01:34:29 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 16
|
|
|
|
|
|
|
|
# complaint on result
|
2019-09-03 21:54:23 +00:00
|
|
|
response = result.complaint_on_result(reported_id=self.WRONG_TASK_ID, captcha_type="recaptcha")
|
2019-06-24 15:17:41 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 16
|
2019-03-01 17:30:53 +00:00
|
|
|
|
2019-06-24 15:17:41 +00:00
|
|
|
def test_fail_control_context(self):
|
2019-03-01 17:30:53 +00:00
|
|
|
# prepare client
|
2019-05-20 20:03:19 +00:00
|
|
|
with AntiCaptchaControl.AntiCaptchaControl(
|
2019-06-24 15:17:41 +00:00
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
2019-05-20 20:03:19 +00:00
|
|
|
) as result:
|
2019-03-01 17:30:53 +00:00
|
|
|
# get balance
|
|
|
|
response = result.get_balance()
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-05-20 20:03:19 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
2019-03-01 17:30:53 +00:00
|
|
|
|
|
|
|
# complaint on result
|
2019-09-03 21:54:23 +00:00
|
|
|
response = result.complaint_on_result(reported_id=self.WRONG_TASK_ID)
|
2019-03-01 17:30:53 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-05-20 20:03:19 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
2019-06-24 15:17:41 +00:00
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-06-24 15:17:41 +00:00
|
|
|
|
2019-08-20 13:02:23 +00:00
|
|
|
# AntiCaptcha Control
|
|
|
|
def test_true_app_stats(self):
|
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.AntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_true
|
|
|
|
)
|
|
|
|
# get balance
|
|
|
|
response = result.get_app_stats(softId=867)
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-08-20 14:56:52 +00:00
|
|
|
assert ["errorId", "chartData", "fromDate", "toDate"] == list(response.keys())
|
2019-08-20 13:02:23 +00:00
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 0
|
|
|
|
|
|
|
|
# get balance
|
2019-08-20 14:56:52 +00:00
|
|
|
response = result.get_app_stats(softId=867, mode="errors")
|
2019-08-20 13:02:23 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-08-20 14:56:52 +00:00
|
|
|
assert ["errorId", "chartData", "fromDate", "toDate"] == list(response.keys())
|
2019-08-20 13:02:23 +00:00
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 0
|
|
|
|
|
|
|
|
# get balance
|
2019-08-20 14:56:52 +00:00
|
|
|
response = result.get_app_stats(softId=867, mode="views")
|
2019-08-20 13:02:23 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-08-20 14:56:52 +00:00
|
|
|
assert ["errorId", "chartData", "fromDate", "toDate"] == list(response.keys())
|
2019-08-20 13:02:23 +00:00
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 0
|
|
|
|
|
|
|
|
# get balance
|
2019-08-20 14:56:52 +00:00
|
|
|
response = result.get_app_stats(softId=867, mode="downloads")
|
2019-08-20 13:02:23 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-08-20 14:56:52 +00:00
|
|
|
assert ["errorId", "chartData", "fromDate", "toDate"] == list(response.keys())
|
2019-08-20 13:02:23 +00:00
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 0
|
|
|
|
|
|
|
|
# get balance
|
2019-08-20 14:56:52 +00:00
|
|
|
response = result.get_app_stats(softId=867, mode="users")
|
2019-08-20 13:02:23 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-08-20 14:56:52 +00:00
|
|
|
assert ["errorId", "chartData", "fromDate", "toDate"] == list(response.keys())
|
2019-08-20 13:02:23 +00:00
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 0
|
|
|
|
|
|
|
|
# get balance
|
2019-08-20 14:56:52 +00:00
|
|
|
response = result.get_app_stats(softId=867, mode="money")
|
2019-08-20 13:02:23 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-08-20 14:56:52 +00:00
|
|
|
assert ["errorId", "chartData", "fromDate", "toDate"] == list(response.keys())
|
2019-08-20 13:02:23 +00:00
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 0
|
|
|
|
|
2019-06-24 15:17:41 +00:00
|
|
|
def test_true_control_context(self):
|
|
|
|
# prepare client
|
|
|
|
with AntiCaptchaControl.AntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_true
|
|
|
|
) as result:
|
|
|
|
# get balance
|
|
|
|
response = result.get_balance()
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "balance"] == list(response.keys())
|
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 0
|
2019-06-24 15:17:41 +00:00
|
|
|
|
|
|
|
# complaint on result
|
2019-09-03 21:54:23 +00:00
|
|
|
response = result.complaint_on_result(reported_id=self.WRONG_TASK_ID)
|
2019-06-24 15:17:41 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 16
|
2019-03-01 17:30:53 +00:00
|
|
|
|
2019-09-03 21:54:23 +00:00
|
|
|
# AntiCaptcha Control
|
|
|
|
@asyncio.coroutine
|
|
|
|
def test_fail_aioqueue_status(self):
|
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.AntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
)
|
|
|
|
q_id = self.WRONG_QUEUE_ID
|
|
|
|
|
|
|
|
with pytest.raises(ValueError):
|
|
|
|
# get queue status
|
|
|
|
assert result.get_queue_status(queue_id=q_id)
|
|
|
|
|
|
|
|
# AntiCaptcha Control
|
|
|
|
@asyncio.coroutine
|
|
|
|
def test_true_aioqueue_status(self):
|
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.aioAntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_true
|
|
|
|
)
|
|
|
|
q_id = random.choice(AntiCaptchaControl.queue_ids)
|
|
|
|
for q_id in AntiCaptchaControl.queue_ids:
|
|
|
|
# get queue status
|
|
|
|
response = yield result.get_queue_status(queue_id=q_id)
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ['waiting', 'load', 'bid', 'speed', 'total'] == list(response.keys())
|
|
|
|
|
2019-03-01 17:30:53 +00:00
|
|
|
@asyncio.coroutine
|
2019-08-20 13:02:23 +00:00
|
|
|
def test_fail_aiobalance(self):
|
2019-03-01 17:30:53 +00:00
|
|
|
# prepare client
|
2019-05-20 20:03:19 +00:00
|
|
|
result = AntiCaptchaControl.aioAntiCaptchaControl(
|
2019-06-24 15:17:41 +00:00
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
2019-05-20 20:03:19 +00:00
|
|
|
)
|
2019-03-01 17:30:53 +00:00
|
|
|
# get balance
|
|
|
|
response = yield result.get_balance()
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-05-20 20:03:19 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
2019-03-01 17:30:53 +00:00
|
|
|
|
2019-08-20 13:02:23 +00:00
|
|
|
@asyncio.coroutine
|
|
|
|
def test_fail_aiocomplaint_on_result(self):
|
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.aioAntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
)
|
2019-03-01 17:30:53 +00:00
|
|
|
# complaint on result
|
2019-09-03 21:54:23 +00:00
|
|
|
response = yield result.complaint_on_result(reported_id=self.WRONG_TASK_ID)
|
2019-03-01 17:30:53 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-05-20 20:03:19 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
2019-06-24 15:17:41 +00:00
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-03-01 17:30:53 +00:00
|
|
|
|
2019-08-21 01:34:29 +00:00
|
|
|
with pytest.raises(ValueError):
|
2019-08-21 01:36:40 +00:00
|
|
|
assert result.complaint_on_result(
|
2019-09-03 21:54:23 +00:00
|
|
|
reported_id=self.WRONG_TASK_ID, captcha_type="not_image"
|
2019-08-21 01:36:40 +00:00
|
|
|
)
|
2019-08-21 01:34:29 +00:00
|
|
|
|
2019-03-01 17:30:53 +00:00
|
|
|
@asyncio.coroutine
|
2019-08-20 13:02:23 +00:00
|
|
|
def test_fail_aioapp_stats(self):
|
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.aioAntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
|
|
|
)
|
|
|
|
# complaint on result
|
|
|
|
response = yield result.get_app_stats(softId=867)
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 1
|
|
|
|
|
|
|
|
with pytest.raises(ValueError):
|
2019-08-20 14:56:52 +00:00
|
|
|
assert result.get_app_stats(softId=867, mode="filure")
|
2019-08-20 13:02:23 +00:00
|
|
|
|
|
|
|
@asyncio.coroutine
|
|
|
|
def test_true_aioapp_stats(self):
|
2019-06-24 15:17:41 +00:00
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.aioAntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_true
|
|
|
|
)
|
2019-08-20 13:02:23 +00:00
|
|
|
# complaint on result
|
|
|
|
response = yield result.get_app_stats(softId=867)
|
2019-06-24 15:17:41 +00:00
|
|
|
# check response type
|
2019-08-20 13:02:23 +00:00
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-08-20 14:56:52 +00:00
|
|
|
assert ["errorId", "chartData", "fromDate", "toDate"] == list(response.keys())
|
2019-08-20 13:02:23 +00:00
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 0
|
2019-06-24 15:17:41 +00:00
|
|
|
|
2019-08-20 13:02:23 +00:00
|
|
|
# get balance
|
2019-08-20 14:56:52 +00:00
|
|
|
response = yield result.get_app_stats(softId=867, mode="errors")
|
2019-08-20 13:02:23 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-08-20 14:56:52 +00:00
|
|
|
assert ["errorId", "chartData", "fromDate", "toDate"] == list(response.keys())
|
2019-08-20 13:02:23 +00:00
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 0
|
|
|
|
|
|
|
|
# get balance
|
2019-08-20 14:56:52 +00:00
|
|
|
response = yield result.get_app_stats(softId=867, mode="views")
|
2019-08-20 13:02:23 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-08-20 14:56:52 +00:00
|
|
|
assert ["errorId", "chartData", "fromDate", "toDate"] == list(response.keys())
|
2019-08-20 13:02:23 +00:00
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 0
|
|
|
|
|
|
|
|
# get balance
|
2019-08-20 14:56:52 +00:00
|
|
|
response = yield result.get_app_stats(softId=867, mode="downloads")
|
2019-08-20 13:02:23 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-08-20 14:56:52 +00:00
|
|
|
assert ["errorId", "chartData", "fromDate", "toDate"] == list(response.keys())
|
2019-08-20 13:02:23 +00:00
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 0
|
|
|
|
|
|
|
|
# get balance
|
2019-08-20 14:56:52 +00:00
|
|
|
response = yield result.get_app_stats(softId=867, mode="users")
|
2019-08-20 13:02:23 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-08-20 14:56:52 +00:00
|
|
|
assert ["errorId", "chartData", "fromDate", "toDate"] == list(response.keys())
|
2019-08-20 13:02:23 +00:00
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 0
|
|
|
|
|
|
|
|
# get balance
|
2019-08-20 14:56:52 +00:00
|
|
|
response = yield result.get_app_stats(softId=867, mode="money")
|
2019-08-20 13:02:23 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-08-20 14:56:52 +00:00
|
|
|
assert ["errorId", "chartData", "fromDate", "toDate"] == list(response.keys())
|
2019-08-20 13:02:23 +00:00
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 0
|
|
|
|
|
|
|
|
@asyncio.coroutine
|
2019-08-21 01:34:29 +00:00
|
|
|
def test_true_aiobalance(self):
|
2019-08-20 13:02:23 +00:00
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.aioAntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_true
|
|
|
|
)
|
2019-06-24 15:17:41 +00:00
|
|
|
# get balance
|
|
|
|
response = yield result.get_balance()
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "balance"] == list(response.keys())
|
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 0
|
2019-06-24 15:17:41 +00:00
|
|
|
|
2019-08-21 01:34:29 +00:00
|
|
|
@asyncio.coroutine
|
|
|
|
def test_true_aiocontrol(self):
|
|
|
|
# prepare client
|
|
|
|
result = AntiCaptchaControl.aioAntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_true
|
|
|
|
)
|
2019-06-24 15:17:41 +00:00
|
|
|
# complaint on result
|
2019-08-21 01:36:40 +00:00
|
|
|
response = yield result.complaint_on_result(
|
2019-09-03 21:54:23 +00:00
|
|
|
reported_id=self.WRONG_TASK_ID, captcha_type="image"
|
2019-08-21 01:36:40 +00:00
|
|
|
)
|
2019-08-21 01:34:29 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
# check error code
|
|
|
|
assert response["errorId"] == 16
|
|
|
|
# complaint on result
|
2019-08-21 01:36:40 +00:00
|
|
|
response = yield result.complaint_on_result(
|
2019-09-03 21:54:23 +00:00
|
|
|
reported_id=self.WRONG_TASK_ID, captcha_type="recaptcha"
|
2019-08-21 01:36:40 +00:00
|
|
|
)
|
2019-06-24 15:17:41 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 16
|
2019-06-24 15:17:41 +00:00
|
|
|
|
|
|
|
@asyncio.coroutine
|
|
|
|
def test_fail_aiocontrol_context(self):
|
2019-03-01 17:30:53 +00:00
|
|
|
# prepare client
|
2019-05-20 20:03:19 +00:00
|
|
|
with AntiCaptchaControl.aioAntiCaptchaControl(
|
2019-06-24 15:17:41 +00:00
|
|
|
anticaptcha_key=self.anticaptcha_key_fail
|
2019-05-20 20:03:19 +00:00
|
|
|
) as result:
|
2019-03-01 17:30:53 +00:00
|
|
|
# get balance
|
|
|
|
response = yield result.get_balance()
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-05-20 20:03:19 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
2019-03-01 17:30:53 +00:00
|
|
|
|
|
|
|
# complaint on result
|
2019-09-03 21:54:23 +00:00
|
|
|
response = yield result.complaint_on_result(reported_id=self.WRONG_TASK_ID)
|
2019-03-01 17:30:53 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
2019-05-20 20:03:19 +00:00
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
2019-06-24 15:17:41 +00:00
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 1
|
2019-06-24 15:17:41 +00:00
|
|
|
|
|
|
|
@asyncio.coroutine
|
|
|
|
def test_true_aiocontrol_context(self):
|
|
|
|
# prepare client
|
|
|
|
with AntiCaptchaControl.aioAntiCaptchaControl(
|
|
|
|
anticaptcha_key=self.anticaptcha_key_true
|
|
|
|
) as result:
|
|
|
|
# get balance
|
|
|
|
response = yield result.get_balance()
|
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "balance"] == list(response.keys())
|
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 0
|
2019-06-24 15:17:41 +00:00
|
|
|
|
|
|
|
# complaint on result
|
2019-09-03 21:54:23 +00:00
|
|
|
response = yield result.complaint_on_result(reported_id=self.WRONG_TASK_ID)
|
2019-06-24 15:17:41 +00:00
|
|
|
# check response type
|
|
|
|
assert type(response) is dict
|
|
|
|
# check all dict keys
|
|
|
|
assert ["errorId", "errorCode", "errorDescription"] == list(response.keys())
|
|
|
|
# check error code
|
2019-07-16 18:48:28 +00:00
|
|
|
assert response["errorId"] == 16
|