add tests for the current address model and validator
This commit is contained in:
parent
34928676c6
commit
be22cf5250
|
@ -49,5 +49,8 @@ docs/_build
|
||||||
# Editors
|
# Editors
|
||||||
.vscode
|
.vscode
|
||||||
|
|
||||||
|
# Pytest
|
||||||
|
.pytest_cache
|
||||||
|
|
||||||
# Project specific
|
# Project specific
|
||||||
example/db.sqlite3
|
example/db.sqlite3
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
# Generated by Django 2.2.5 on 2019-10-15 14:37
|
# Generated by Django 2.2.5 on 2019-10-15 17:25
|
||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
from django.db import migrations, models
|
from django.db import migrations, models
|
||||||
|
@ -23,7 +23,7 @@ class Migration(migrations.Migration):
|
||||||
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
('created', model_utils.fields.AutoCreatedField(default=django.utils.timezone.now, editable=False, verbose_name='created')),
|
('created', model_utils.fields.AutoCreatedField(default=django.utils.timezone.now, editable=False, verbose_name='created')),
|
||||||
('modified', model_utils.fields.AutoLastModifiedField(default=django.utils.timezone.now, editable=False, verbose_name='modified')),
|
('modified', model_utils.fields.AutoLastModifiedField(default=django.utils.timezone.now, editable=False, verbose_name='modified')),
|
||||||
('address', models.CharField(max_length=106, validators=[django_cryptolock.validators.validate_monero_address])),
|
('address', models.CharField(max_length=106, unique=True, validators=[django_cryptolock.validators.validate_monero_address])),
|
||||||
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
||||||
],
|
],
|
||||||
options={
|
options={
|
||||||
|
|
|
@ -1,19 +0,0 @@
|
||||||
# Generated by Django 2.2.5 on 2019-10-15 16:41
|
|
||||||
|
|
||||||
from django.conf import settings
|
|
||||||
from django.db import migrations
|
|
||||||
|
|
||||||
|
|
||||||
class Migration(migrations.Migration):
|
|
||||||
|
|
||||||
dependencies = [
|
|
||||||
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
|
|
||||||
('django_cryptolock', '0001_initial'),
|
|
||||||
]
|
|
||||||
|
|
||||||
operations = [
|
|
||||||
migrations.AlterUniqueTogether(
|
|
||||||
name='address',
|
|
||||||
unique_together={('user', 'address')},
|
|
||||||
),
|
|
||||||
]
|
|
|
@ -13,14 +13,15 @@ class Address(TimeStampedModel):
|
||||||
"""Addresses that belong to a given user account."""
|
"""Addresses that belong to a given user account."""
|
||||||
|
|
||||||
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
|
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
|
||||||
address = models.CharField(max_length=106, validators=[validate_monero_address])
|
address = models.CharField(
|
||||||
|
max_length=106, validators=[validate_monero_address], unique=True
|
||||||
|
)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
"""Meta definition for Address."""
|
"""Meta definition for Address."""
|
||||||
|
|
||||||
verbose_name = _("Address")
|
verbose_name = _("Address")
|
||||||
verbose_name_plural = _("Addresses")
|
verbose_name_plural = _("Addresses")
|
||||||
unique_together = ["user", "address"]
|
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
"""Unicode representation of Address."""
|
"""Unicode representation of Address."""
|
||||||
|
|
|
@ -13,7 +13,7 @@ def validate_monero_address(value):
|
||||||
_("%(value)s is not a valid address"), params={"value": value}
|
_("%(value)s is not a valid address"), params={"value": value}
|
||||||
)
|
)
|
||||||
|
|
||||||
network = getattr(settings, "MONERO_NETWORK", None)
|
network = getattr(settings, "DJCL_MONERO_NETWORK", None)
|
||||||
if not network:
|
if not network:
|
||||||
raise ValidationError(
|
raise ValidationError(
|
||||||
_("Please configure the monero network in the settings file")
|
_("Please configure the monero network in the settings file")
|
||||||
|
|
|
@ -8,3 +8,4 @@ coveralls
|
||||||
pytest
|
pytest
|
||||||
pytest-django
|
pytest-django
|
||||||
pytest-cov
|
pytest-cov
|
||||||
|
model_mommy
|
||||||
|
|
|
@ -27,6 +27,15 @@ if django.VERSION >= (1, 10):
|
||||||
else:
|
else:
|
||||||
MIDDLEWARE_CLASSES = ()
|
MIDDLEWARE_CLASSES = ()
|
||||||
|
|
||||||
MONERO_WALLET_RPC_HOST = "localhost:3030"
|
AUTHENTICATION_BACKENDS = [
|
||||||
MONERO_WALLET_RPC_USER = "test"
|
"django_cryptolock.backends.MoneroAddressBackend",
|
||||||
MONERO_WALLET_RPC_PASS = "test"
|
"django.contrib.auth.backends.ModelBackend",
|
||||||
|
]
|
||||||
|
|
||||||
|
# Test only default settings
|
||||||
|
DJCL_MONERO_NETWORK = "stagenet"
|
||||||
|
|
||||||
|
DJCL_MONERO_WALLET_RPC_HOST = "localhost:3030"
|
||||||
|
DJCL_MONERO_WALLET_RPC_USER = "test"
|
||||||
|
DJCL_MONERO_WALLET_RPC_PASS = "test"
|
||||||
|
DJCL_MONERO_WALLET_RPC_PROTOCOL = "http"
|
||||||
|
|
|
@ -7,18 +7,64 @@ test_django-cryptolock
|
||||||
|
|
||||||
Tests for `django-cryptolock` models module.
|
Tests for `django-cryptolock` models module.
|
||||||
"""
|
"""
|
||||||
|
from django.core.exceptions import ValidationError
|
||||||
|
from django.db import IntegrityError
|
||||||
|
|
||||||
from django.test import TestCase
|
import pytest
|
||||||
|
from model_mommy import mommy
|
||||||
|
|
||||||
from django_cryptolock import models
|
from django_cryptolock.models import Address
|
||||||
|
|
||||||
|
VALID_MONERO_MAINNET_ADDR = "45D8b4XiUdz86FwztAJHVeLnQqGHQUqiHSwZe6rXFHSoXw522dPdixsdi7JAGsfJsfHRCP94UFhY5W3U8KCBhsRNUSLbYFk"
|
||||||
|
VALID_MONERO_STAGENET_ADDR = "55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt"
|
||||||
|
VALID_MONERO_TESTNET_ADDR = "9vmn8Vyxh6JEVmPr4qTcj3ND3FywDpMXH2fVLLEARyKCJTc3jWjxeWcbRNcaa57Bj36cARBSfWnfS89oFVKBBvGTAegdRxG"
|
||||||
|
|
||||||
|
pytestmark = pytest.mark.django_db
|
||||||
|
|
||||||
|
|
||||||
class TestDjango_cryptolock(TestCase):
|
def test_valid_mainnet_address(settings):
|
||||||
def setUp(self):
|
settings.DJCL_MONERO_NETWORK = "mainnet"
|
||||||
pass
|
|
||||||
|
|
||||||
def test_something(self):
|
addr = mommy.make(Address, address=VALID_MONERO_MAINNET_ADDR)
|
||||||
pass
|
addr.full_clean()
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
pass
|
def test_valid_stagenet_addr(settings):
|
||||||
|
settings.DJCL_MONERO_NETWORK = "stagenet"
|
||||||
|
|
||||||
|
addr = mommy.make(Address, address=VALID_MONERO_STAGENET_ADDR)
|
||||||
|
addr.full_clean()
|
||||||
|
|
||||||
|
|
||||||
|
def test_valid_testnet_addr(settings):
|
||||||
|
settings.DJCL_MONERO_NETWORK = "testnet"
|
||||||
|
|
||||||
|
addr = mommy.make(Address, address=VALID_MONERO_TESTNET_ADDR)
|
||||||
|
addr.full_clean()
|
||||||
|
|
||||||
|
|
||||||
|
def test_invalid_address():
|
||||||
|
bad_addr = "Verywrongaddress"
|
||||||
|
addr = mommy.make(Address, address=bad_addr)
|
||||||
|
|
||||||
|
with pytest.raises(ValidationError) as error:
|
||||||
|
addr.full_clean()
|
||||||
|
|
||||||
|
assert f"{bad_addr} is not a valid address" in error.value.message_dict["address"]
|
||||||
|
|
||||||
|
|
||||||
|
def test_wrong_network_address(settings):
|
||||||
|
settings.DJCL_MONERO_NETWORK = "stagenet"
|
||||||
|
addr = mommy.make(Address, address=VALID_MONERO_MAINNET_ADDR)
|
||||||
|
|
||||||
|
with pytest.raises(ValidationError) as error:
|
||||||
|
addr.full_clean()
|
||||||
|
|
||||||
|
assert "Invalid address for stagenet" in error.value.message_dict["address"]
|
||||||
|
|
||||||
|
|
||||||
|
def test_address_is_unique():
|
||||||
|
addr = mommy.make(Address, address=VALID_MONERO_MAINNET_ADDR)
|
||||||
|
|
||||||
|
with pytest.raises(IntegrityError):
|
||||||
|
mommy.make(Address, address=VALID_MONERO_MAINNET_ADDR)
|
||||||
|
|
Loading…
Reference in New Issue