testa meglio

This commit is contained in:
boyska 2020-10-01 20:29:27 +02:00
parent ce80fe857d
commit dd73232769
2 changed files with 75 additions and 51 deletions

View file

@ -1,8 +1,9 @@
"""Console script for banana.""" """Console script for banana."""
import argparse import argparse
from . import bananalib as banana
import sys import sys
from . import bananalib as banana
def ananas2dec(): def ananas2dec():
parser = argparse.ArgumentParser(description="Convert ananas string to dec") parser = argparse.ArgumentParser(description="Convert ananas string to dec")
@ -23,12 +24,16 @@ def avocado2dec():
def banana2dec(): def banana2dec():
parser = argparse.ArgumentParser(description="Convert banana string to dec") parser = argparse.ArgumentParser(description="Convert banana string to dec")
parser.add_argument("banana", help="String to be converted") parser.add_argument("banana", help="String to be converted")
parser.add_argument("--dictionary", help="Set dictionary", type=list, nargs='+') parser.add_argument("--dictionary", help="Set dictionary", type=list, nargs="+")
parser.add_argument("--dictstart", help="Set starting dictionary", type=int, default=0) parser.add_argument(
parser.add_argument("--shiftend", help="Set shift for ending dictionary", type=int, default=0) "--dictstart", help="Set starting dictionary", type=int, default=0
)
parser.add_argument(
"--shiftend", help="Set shift for ending dictionary", type=int, default=0
)
args = parser.parse_args() args = parser.parse_args()
print(banana.banana2dec(args.banana, args.dictstart, args.shiftend, args.dictionary)) print(banana.banana2dec(args.banana))
def ribes2dec(): def ribes2dec():
@ -41,13 +46,21 @@ def ribes2dec():
def bananarandom(): def bananarandom():
parser = argparse.ArgumentParser(description="Generate random banana") parser = argparse.ArgumentParser(description="Generate random banana")
parser.add_argument("--dictionary", help="Set dictionary", type=list, nargs='+') parser.add_argument("--dictionary", help="Set dictionary", type=list, nargs="+")
parser.add_argument("--dictstart", help="Set starting dictionary", type=int, default=0) parser.add_argument(
parser.add_argument("--shiftend", help="Set shift for ending dictionary", type=int, default=0) "--dictstart", help="Set starting dictionary", type=int, default=0
)
parser.add_argument(
"--shiftend", help="Set shift for ending dictionary", type=int, default=0
)
parser.add_argument("--minlength", help="Set minimum length", type=int, default=6) parser.add_argument("--minlength", help="Set minimum length", type=int, default=6)
args = parser.parse_args() args = parser.parse_args()
print(banana.bananarandom(args.dictstart, args.shiftend, args.minlength, args.dictionary)) print(
banana.bananarandom(
args.dictstart, args.shiftend, args.minlength, args.dictionary
)
)
def dec2ananas(): def dec2ananas():
@ -71,13 +84,21 @@ def dec2avocado():
def dec2banana(): def dec2banana():
parser = argparse.ArgumentParser(description="Convert dec number to banana") parser = argparse.ArgumentParser(description="Convert dec number to banana")
parser.add_argument("num", help="Number to be converted", type=int) parser.add_argument("num", help="Number to be converted", type=int)
parser.add_argument("--dictionary", help="Set dictionary", type=list, nargs='+') parser.add_argument("--dictionary", help="Set dictionary", type=list, nargs="+")
parser.add_argument("--dictstart", help="Set starting dictionary", type=int, default=0) parser.add_argument(
parser.add_argument("--shiftend", help="Set shift for ending dictionary", type=int, default=0) "--dictstart", help="Set starting dictionary", type=int, default=0
)
parser.add_argument(
"--shiftend", help="Set shift for ending dictionary", type=int, default=0
)
parser.add_argument("--minlength", help="Set minimum length", type=int, default=0) parser.add_argument("--minlength", help="Set minimum length", type=int, default=0)
args = parser.parse_args() args = parser.parse_args()
print(banana.dec2banana(args.num, args.dictstart, args.shiftend, args.minlength, args.dictionary)) print(
banana.dec2banana(
args.num, args.dictstart, args.shiftend, args.minlength, args.dictionary
)
)
def dec2ribes(): def dec2ribes():
@ -92,9 +113,13 @@ def dec2ribes():
def isbanana(): def isbanana():
parser = argparse.ArgumentParser(description="Checks if string is banana") parser = argparse.ArgumentParser(description="Checks if string is banana")
parser.add_argument("banana", help="String to be checked") parser.add_argument("banana", help="String to be checked")
parser.add_argument("--dictionary", help="Set dictionary", type=list, nargs='+') parser.add_argument("--dictionary", help="Set dictionary", type=list, nargs="+")
parser.add_argument("--dictstart", help="Set starting dictionary", type=int, default=0) parser.add_argument(
parser.add_argument("--shiftend", help="Set shift for ending dictionary", type=int, default=0) "--dictstart", help="Set starting dictionary", type=int, default=0
)
parser.add_argument(
"--shiftend", help="Set shift for ending dictionary", type=int, default=0
)
args = parser.parse_args() args = parser.parse_args()
print(banana.isbanana(args.banana, args.dictstart, args.shiftend, args.dictionary)) print(banana.isbanana(args.banana, args.dictstart, args.shiftend, args.dictionary))
@ -107,4 +132,3 @@ def main():
if __name__ == "__main__": if __name__ == "__main__":
# pragma: no cover # pragma: no cover
main() main()

View file

@ -6,16 +6,13 @@ import pytest
from banana import (avocado2dec, banana2dec, dec2avocado, dec2banana, from banana import (avocado2dec, banana2dec, dec2avocado, dec2banana,
dec2ribes, ribes2dec) dec2ribes, ribes2dec)
banana_conversions = { banana_conversions = {"be": 1, "beba": 70, "zu": 69, "bezu": 139, "nana": 2485}
"ba": 0,
"baba": 0,
"be": 1, @pytest.fixture(params=banana_conversions.items())
"beba": 70, def banana_known(request):
"zu": 69, yield request.param
"bezu": 139,
"nana": 2485,
"banana": 2485,
}
avocado_conversions = { avocado_conversions = {
"a": 0, "a": 0,
@ -39,6 +36,12 @@ avocado_conversions = {
"ega": 90, "ega": 90,
} }
@pytest.fixture(params=avocado_conversions.items())
def avocado_known(request):
yield request.param
ribes_conversions = {"b": 0, "c": 1, "z": 13, "beb": 14, "bec": 15} ribes_conversions = {"b": 0, "c": 1, "z": 13, "beb": 14, "bec": 15}
@ -47,24 +50,21 @@ def ribes_known(request):
yield request.param yield request.param
def test_banana_to_dec_known(): def test_banana_to_dec_known(banana_known):
for word, value in banana_conversions.items(): word, value = banana_known
assert banana2dec(word) == value assert banana2dec(word) == value
def test_banana2dec_prefix_ba(): def test_dec_to_banana_known(banana_known):
word, value = banana_known
assert dec2banana(value) == word
def test_banana2dec_prefix_ba(banana_known):
"""un ba all'inizio non cambia nulla!""" """un ba all'inizio non cambia nulla!"""
for word in banana_conversions: word, value = banana_known
value = banana2dec(word) for prefix in ("ba", "baba", "bababa"):
for prefix in ("ba", "baba", "bababa"): assert banana2dec(prefix + word) == value
assert banana2dec(prefix + word) == value
def test_dec_to_banana_known():
for word, value in banana_conversions.items():
if word.startswith("ba"):
continue
assert dec2banana(value) == word
def test_ribes_to_dec_known(ribes_known): def test_ribes_to_dec_known(ribes_known):
@ -72,19 +72,19 @@ def test_ribes_to_dec_known(ribes_known):
assert ribes2dec(word) == value assert ribes2dec(word) == value
def test_dec_to_ribes_known(): def test_dec_to_ribes_known(ribes_known):
for word, value in ribes_conversions.items(): word, value = ribes_known
assert dec2ribes(value) == word assert dec2ribes(value) == word
def test_avocado_to_dec_known(): def test_avocado_to_dec_known(avocado_known):
for word, value in avocado_conversions.items(): word, value = avocado_known
assert avocado2dec(word) == value assert avocado2dec(word) == value
def test_dec_to_avocado_known(): def test_dec_to_avocado_known(avocado_known):
for word, value in avocado_conversions.items(): word, value = avocado_known
assert dec2avocado(value) == word assert dec2avocado(value) == word
def test_answer_to_life_the_universe_and_everything(): def test_answer_to_life_the_universe_and_everything():