forked from itec/banana
fix ribes + add avocado
This commit is contained in:
parent
b4ba921ed3
commit
ce80fe857d
2 changed files with 36 additions and 9 deletions
|
@ -30,14 +30,14 @@ def decoder(banana, dictstart=0, shiftend=0, dictionary=None):
|
||||||
|
|
||||||
numdict = len(dictionary)
|
numdict = len(dictionary)
|
||||||
if (len(banana) - shiftend) % numdict != 0:
|
if (len(banana) - shiftend) % numdict != 0:
|
||||||
return "Banana non valida"
|
raise ValueError("Banana non valida")
|
||||||
v = 0
|
v = 0
|
||||||
for i in range(len(banana)):
|
for i in range(len(banana)):
|
||||||
r = (numdict + i + dictstart) % numdict
|
r = (numdict + i + dictstart) % numdict
|
||||||
try:
|
try:
|
||||||
v = v * len(dictionary[r]) + dictionary[r].index(banana[i])
|
v = v * len(dictionary[r]) + dictionary[r].index(banana[i])
|
||||||
except (ValueError, KeyError) as e:
|
except (ValueError, KeyError):
|
||||||
return "Carattere non valido in posizione", i + 1
|
raise ValueError("Carattere non valido in posizione %d" % i + 1)
|
||||||
|
|
||||||
return v
|
return v
|
||||||
|
|
||||||
|
@ -51,10 +51,18 @@ def dec2banana(word):
|
||||||
|
|
||||||
|
|
||||||
def ribes2dec(word):
|
def ribes2dec(word):
|
||||||
return decoder(word, 1, 1)
|
return decoder(word, 0, 1)
|
||||||
|
|
||||||
|
|
||||||
def dec2ribes(word):
|
def dec2ribes(word):
|
||||||
|
return encoder(word, 0, 1)
|
||||||
|
|
||||||
|
|
||||||
|
def avocado2dec(word):
|
||||||
|
return decoder(word, 1, 1)
|
||||||
|
|
||||||
|
|
||||||
|
def dec2avocado(word):
|
||||||
return encoder(word, 1, 1)
|
return encoder(word, 1, 1)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,10 @@
|
||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
"""Tests for `banana` package."""
|
"""Tests for `banana` package."""
|
||||||
|
import pytest
|
||||||
|
|
||||||
from banana import banana2dec, dec2banana, dec2ribes, ribes2dec
|
from banana import (avocado2dec, banana2dec, dec2avocado, dec2banana,
|
||||||
|
dec2ribes, ribes2dec)
|
||||||
|
|
||||||
banana_conversions = {
|
banana_conversions = {
|
||||||
"ba": 0,
|
"ba": 0,
|
||||||
|
@ -15,7 +17,7 @@ banana_conversions = {
|
||||||
"banana": 2485,
|
"banana": 2485,
|
||||||
}
|
}
|
||||||
|
|
||||||
ribes_conversions = {
|
avocado_conversions = {
|
||||||
"a": 0,
|
"a": 0,
|
||||||
"aca": 5,
|
"aca": 5,
|
||||||
"ada": 10,
|
"ada": 10,
|
||||||
|
@ -37,6 +39,13 @@ ribes_conversions = {
|
||||||
"ega": 90,
|
"ega": 90,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ribes_conversions = {"b": 0, "c": 1, "z": 13, "beb": 14, "bec": 15}
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture(params=ribes_conversions.items())
|
||||||
|
def ribes_known(request):
|
||||||
|
yield request.param
|
||||||
|
|
||||||
|
|
||||||
def test_banana_to_dec_known():
|
def test_banana_to_dec_known():
|
||||||
for word, value in banana_conversions.items():
|
for word, value in banana_conversions.items():
|
||||||
|
@ -58,8 +67,8 @@ def test_dec_to_banana_known():
|
||||||
assert dec2banana(value) == word
|
assert dec2banana(value) == word
|
||||||
|
|
||||||
|
|
||||||
def test_ribes_to_dec_known():
|
def test_ribes_to_dec_known(ribes_known):
|
||||||
for word, value in ribes_conversions.items():
|
word, value = ribes_known
|
||||||
assert ribes2dec(word) == value
|
assert ribes2dec(word) == value
|
||||||
|
|
||||||
|
|
||||||
|
@ -68,6 +77,16 @@ def test_dec_to_ribes_known():
|
||||||
assert dec2ribes(value) == word
|
assert dec2ribes(value) == word
|
||||||
|
|
||||||
|
|
||||||
|
def test_avocado_to_dec_known():
|
||||||
|
for word, value in avocado_conversions.items():
|
||||||
|
assert avocado2dec(word) == value
|
||||||
|
|
||||||
|
|
||||||
|
def test_dec_to_avocado_known():
|
||||||
|
for word, value in avocado_conversions.items():
|
||||||
|
assert dec2avocado(value) == word
|
||||||
|
|
||||||
|
|
||||||
def test_answer_to_life_the_universe_and_everything():
|
def test_answer_to_life_the_universe_and_everything():
|
||||||
banana = banana2dec("banana")
|
banana = banana2dec("banana")
|
||||||
assert banana != 42
|
assert banana != 42
|
||||||
|
|
Loading…
Reference in a new issue