Update control logic and tests
This commit is contained in:
parent
3ada499065
commit
cc0dde2cca
|
@ -1,15 +1,20 @@
|
||||||
import aiohttp
|
import aiohttp
|
||||||
import requests
|
import requests
|
||||||
|
|
||||||
from python3_anticaptcha import (
|
# Адрес для получения баланса
|
||||||
get_balance_url,
|
get_balance_url = "https://api.anti-captcha.com/getBalance"
|
||||||
get_app_stats_url,
|
# Адрес для отправки жалобы на неверное решение капчи-изображения
|
||||||
get_queue_status_url,
|
incorrect_imagecaptcha_url = "https://api.anti-captcha.com/reportIncorrectImageCaptcha"
|
||||||
incorrect_recaptcha_url,
|
# Адрес для отправки жалобы на неверное решение ReCaptcha
|
||||||
incorrect_imagecaptcha_url,
|
incorrect_recaptcha_url = "https://api.anti-captcha.com/reportIncorrectRecaptcha"
|
||||||
get_spend_stats_url,
|
# Адрес для получения информации о очереди
|
||||||
send_funds_url,
|
get_queue_status_url = "https://api.anti-captcha.com/getQueueStats"
|
||||||
)
|
# С помощью этого метода можно получить статистику трат за последние 24 часа.
|
||||||
|
get_spend_stats_url = "https://api.anti-captcha.com/getSpendingStats"
|
||||||
|
# Адрес для получения информации о приложении
|
||||||
|
get_app_stats_url = "https://api.anti-captcha.com/getAppStats"
|
||||||
|
# С помощью этого метода можно получить статистику трат за последние 24 часа.
|
||||||
|
send_funds_url = "https://api.anti-captcha.com/sendFunds"
|
||||||
|
|
||||||
# available app stats mods
|
# available app stats mods
|
||||||
mods = ("errors", "views", "downloads", "users", "money")
|
mods = ("errors", "views", "downloads", "users", "money")
|
||||||
|
@ -218,7 +223,10 @@ class aioAntiCaptchaControl:
|
||||||
async with session.post(
|
async with session.post(
|
||||||
get_balance_url, json={"clientKey": self.ANTICAPTCHA_KEY}
|
get_balance_url, json={"clientKey": self.ANTICAPTCHA_KEY}
|
||||||
) as resp:
|
) as resp:
|
||||||
return await resp.json()
|
if await resp.text():
|
||||||
|
return await resp.json()
|
||||||
|
else:
|
||||||
|
return {"errorId": 1}
|
||||||
|
|
||||||
async def send_funds(
|
async def send_funds(
|
||||||
self, accountLogin: str = None, accountEmail: str = None, amount: float = None
|
self, accountLogin: str = None, accountEmail: str = None, amount: float = None
|
||||||
|
@ -241,7 +249,10 @@ class aioAntiCaptchaControl:
|
||||||
# get response
|
# get response
|
||||||
async with aiohttp.ClientSession() as session:
|
async with aiohttp.ClientSession() as session:
|
||||||
async with session.post(send_funds_url, json=payload) as resp:
|
async with session.post(send_funds_url, json=payload) as resp:
|
||||||
return await resp.json()
|
if await resp.text():
|
||||||
|
return await resp.json()
|
||||||
|
else:
|
||||||
|
return {"errorId": 1}
|
||||||
|
|
||||||
async def get_spend_stats(
|
async def get_spend_stats(
|
||||||
self, date: int = None, queue: str = None, softId: int = None, ip: str = None
|
self, date: int = None, queue: str = None, softId: int = None, ip: str = None
|
||||||
|
@ -270,7 +281,10 @@ class aioAntiCaptchaControl:
|
||||||
# get response
|
# get response
|
||||||
async with aiohttp.ClientSession() as session:
|
async with aiohttp.ClientSession() as session:
|
||||||
async with session.post(get_spend_stats_url, json=payload) as resp:
|
async with session.post(get_spend_stats_url, json=payload) as resp:
|
||||||
return await resp.json()
|
if await resp.text():
|
||||||
|
return await resp.json()
|
||||||
|
else:
|
||||||
|
return {"errorId": 1}
|
||||||
|
|
||||||
async def get_app_stats(self, softId: int, mode: str = "errors") -> dict:
|
async def get_app_stats(self, softId: int, mode: str = "errors") -> dict:
|
||||||
"""
|
"""
|
||||||
|
@ -284,7 +298,10 @@ class aioAntiCaptchaControl:
|
||||||
payload = {"clientKey": self.ANTICAPTCHA_KEY, "softId": softId, "mode": mode}
|
payload = {"clientKey": self.ANTICAPTCHA_KEY, "softId": softId, "mode": mode}
|
||||||
async with aiohttp.ClientSession() as session:
|
async with aiohttp.ClientSession() as session:
|
||||||
async with session.post(get_app_stats_url, json=payload) as resp:
|
async with session.post(get_app_stats_url, json=payload) as resp:
|
||||||
return await resp.json()
|
if await resp.text():
|
||||||
|
return await resp.json()
|
||||||
|
else:
|
||||||
|
return {"errorId": 1}
|
||||||
|
|
||||||
async def complaint_on_result(self, reported_id: int, captcha_type: str = "image") -> dict:
|
async def complaint_on_result(self, reported_id: int, captcha_type: str = "image") -> dict:
|
||||||
f"""
|
f"""
|
||||||
|
@ -304,12 +321,18 @@ class aioAntiCaptchaControl:
|
||||||
if captcha_type == "image":
|
if captcha_type == "image":
|
||||||
async with aiohttp.ClientSession() as session:
|
async with aiohttp.ClientSession() as session:
|
||||||
async with session.post(incorrect_imagecaptcha_url, json=payload) as resp:
|
async with session.post(incorrect_imagecaptcha_url, json=payload) as resp:
|
||||||
return await resp.json()
|
if await resp.text():
|
||||||
|
return await resp.json()
|
||||||
|
else:
|
||||||
|
return {"errorId": 1}
|
||||||
# complaint on re-captcha
|
# complaint on re-captcha
|
||||||
elif captcha_type == "recaptcha":
|
elif captcha_type == "recaptcha":
|
||||||
async with aiohttp.ClientSession() as session:
|
async with aiohttp.ClientSession() as session:
|
||||||
async with session.post(incorrect_recaptcha_url, json=payload) as resp:
|
async with session.post(incorrect_recaptcha_url, json=payload) as resp:
|
||||||
return await resp.json()
|
if await resp.text():
|
||||||
|
return await resp.json()
|
||||||
|
else:
|
||||||
|
return {"errorId": 1}
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
async def get_queue_status(queue_id: int) -> dict:
|
async def get_queue_status(queue_id: int) -> dict:
|
||||||
|
@ -347,4 +370,7 @@ class aioAntiCaptchaControl:
|
||||||
|
|
||||||
async with aiohttp.ClientSession() as session:
|
async with aiohttp.ClientSession() as session:
|
||||||
async with session.post(get_queue_status_url, json=payload) as resp:
|
async with session.post(get_queue_status_url, json=payload) as resp:
|
||||||
return await resp.json()
|
if await resp.text():
|
||||||
|
return await resp.json()
|
||||||
|
else:
|
||||||
|
return {"errorId": 1}
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
import json
|
import json
|
||||||
import time
|
import time
|
||||||
|
|
||||||
|
import pika
|
||||||
import requests
|
import requests
|
||||||
|
|
||||||
import pika
|
|
||||||
from python3_anticaptcha import (
|
from python3_anticaptcha import (
|
||||||
HOST,
|
HOST,
|
||||||
PORT,
|
PORT,
|
||||||
|
|
|
@ -9,13 +9,6 @@ from .config import (
|
||||||
app_key,
|
app_key,
|
||||||
get_result_url,
|
get_result_url,
|
||||||
create_task_url,
|
create_task_url,
|
||||||
get_balance_url,
|
|
||||||
get_app_stats_url,
|
|
||||||
get_queue_status_url,
|
|
||||||
incorrect_recaptcha_url,
|
|
||||||
incorrect_imagecaptcha_url,
|
|
||||||
send_funds_url,
|
|
||||||
get_spend_stats_url,
|
|
||||||
)
|
)
|
||||||
from .errors import ReadError, IdGetError, ParamError
|
from .errors import ReadError, IdGetError, ParamError
|
||||||
from .get_answer import get_sync_result, get_async_result
|
from .get_answer import get_sync_result, get_async_result
|
||||||
|
|
|
@ -6,20 +6,6 @@ urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
|
||||||
create_task_url = "https://api.anti-captcha.com/createTask"
|
create_task_url = "https://api.anti-captcha.com/createTask"
|
||||||
# Адрес для получения ответа
|
# Адрес для получения ответа
|
||||||
get_result_url = "https://api.anti-captcha.com/getTaskResult"
|
get_result_url = "https://api.anti-captcha.com/getTaskResult"
|
||||||
# Адрес для получения баланса
|
|
||||||
get_balance_url = "https://api.anti-captcha.com/getBalance"
|
|
||||||
# Адрес для отправки жалобы на неверное решение капчи-изображения
|
|
||||||
incorrect_imagecaptcha_url = "https://api.anti-captcha.com/reportIncorrectImageCaptcha"
|
|
||||||
# Адрес для отправки жалобы на неверное решение ReCaptcha
|
|
||||||
incorrect_recaptcha_url = "https://api.anti-captcha.com/reportIncorrectRecaptcha"
|
|
||||||
# Адрес для получения информации о очереди
|
|
||||||
get_queue_status_url = "https://api.anti-captcha.com/getQueueStats"
|
|
||||||
# С помощью этого метода можно получить статистику трат за последние 24 часа.
|
|
||||||
get_spend_stats_url = "https://api.anti-captcha.com/getSpendingStats"
|
|
||||||
# Адрес для получения информации о приложении
|
|
||||||
get_app_stats_url = "https://api.anti-captcha.com/getAppStats"
|
|
||||||
# С помощью этого метода можно получить статистику трат за последние 24 часа.
|
|
||||||
send_funds_url = "https://api.anti-captcha.com/sendFunds"
|
|
||||||
# ключ приложения
|
# ключ приложения
|
||||||
app_key = "867"
|
app_key = "867"
|
||||||
|
|
||||||
|
|
|
@ -74,7 +74,7 @@ class TestControl(MainAntiCaptcha):
|
||||||
assert isinstance(control, AntiCaptchaControl.AntiCaptchaControl)
|
assert isinstance(control, AntiCaptchaControl.AntiCaptchaControl)
|
||||||
|
|
||||||
with requests_mock.Mocker() as req_mock:
|
with requests_mock.Mocker() as req_mock:
|
||||||
req_mock.post(config.get_balance_url, json=self.ERROR_RESPONSE_JSON)
|
req_mock.post(AntiCaptchaControl.get_balance_url, json=self.ERROR_RESPONSE_JSON)
|
||||||
control.get_balance()
|
control.get_balance()
|
||||||
|
|
||||||
history = req_mock.request_history
|
history = req_mock.request_history
|
||||||
|
@ -94,7 +94,7 @@ class TestControl(MainAntiCaptcha):
|
||||||
mode = random.choice(AntiCaptchaControl.mods)
|
mode = random.choice(AntiCaptchaControl.mods)
|
||||||
|
|
||||||
with requests_mock.Mocker() as req_mock:
|
with requests_mock.Mocker() as req_mock:
|
||||||
req_mock.post(config.get_app_stats_url, json=self.ERROR_RESPONSE_JSON)
|
req_mock.post(AntiCaptchaControl.get_app_stats_url, json=self.ERROR_RESPONSE_JSON)
|
||||||
control.get_app_stats(softId=config.app_key, mode=mode)
|
control.get_app_stats(softId=config.app_key, mode=mode)
|
||||||
|
|
||||||
history = req_mock.request_history
|
history = req_mock.request_history
|
||||||
|
@ -116,7 +116,7 @@ class TestControl(MainAntiCaptcha):
|
||||||
task_id = 123456
|
task_id = 123456
|
||||||
|
|
||||||
with requests_mock.Mocker() as req_mock:
|
with requests_mock.Mocker() as req_mock:
|
||||||
req_mock.post(config.incorrect_imagecaptcha_url, json=self.ERROR_RESPONSE_JSON)
|
req_mock.post(AntiCaptchaControl.incorrect_imagecaptcha_url, json=self.ERROR_RESPONSE_JSON)
|
||||||
control.complaint_on_result(
|
control.complaint_on_result(
|
||||||
reported_id=task_id, captcha_type=AntiCaptchaControl.complaint_types[0]
|
reported_id=task_id, captcha_type=AntiCaptchaControl.complaint_types[0]
|
||||||
)
|
)
|
||||||
|
@ -139,7 +139,7 @@ class TestControl(MainAntiCaptcha):
|
||||||
task_id = 123456
|
task_id = 123456
|
||||||
|
|
||||||
with requests_mock.Mocker() as req_mock:
|
with requests_mock.Mocker() as req_mock:
|
||||||
req_mock.post(config.incorrect_recaptcha_url, json=self.ERROR_RESPONSE_JSON)
|
req_mock.post(AntiCaptchaControl.incorrect_recaptcha_url, json=self.ERROR_RESPONSE_JSON)
|
||||||
control.complaint_on_result(
|
control.complaint_on_result(
|
||||||
reported_id=task_id, captcha_type=AntiCaptchaControl.complaint_types[1]
|
reported_id=task_id, captcha_type=AntiCaptchaControl.complaint_types[1]
|
||||||
)
|
)
|
||||||
|
@ -158,7 +158,7 @@ class TestControl(MainAntiCaptcha):
|
||||||
def test_queue_payload(self):
|
def test_queue_payload(self):
|
||||||
queue_id = random.choice(AntiCaptchaControl.queue_ids)
|
queue_id = random.choice(AntiCaptchaControl.queue_ids)
|
||||||
with requests_mock.Mocker() as req_mock:
|
with requests_mock.Mocker() as req_mock:
|
||||||
req_mock.post(config.get_queue_status_url, json=self.ERROR_RESPONSE_JSON)
|
req_mock.post(AntiCaptchaControl.get_queue_status_url, json=self.ERROR_RESPONSE_JSON)
|
||||||
AntiCaptchaControl.AntiCaptchaControl.get_queue_status(queue_id)
|
AntiCaptchaControl.AntiCaptchaControl.get_queue_status(queue_id)
|
||||||
|
|
||||||
history = req_mock.request_history
|
history = req_mock.request_history
|
||||||
|
|
Loading…
Reference in New Issue