All Projects → luisprooc → pelt-testing

luisprooc / pelt-testing

Licence: MIT license
A library testing for python, this package allows us to test algorithms and generate test data.

Programming Languages

python
139335 projects - #7 most used programming language

Projects that are alternatives of or similar to pelt-testing

S Tui
Terminal-based CPU stress and monitoring utility
Stars: ✭ 2,825 (+20078.57%)
Mutual labels:  console
Laravel Zero
A PHP framework for console artisans
Stars: ✭ 2,821 (+20050%)
Mutual labels:  console
Console Kit
💻 APIs for creating interactive CLI tools.
Stars: ✭ 252 (+1700%)
Mutual labels:  console
Chromelogger Python
Python library for logging variables to Google Chrome console
Stars: ✭ 232 (+1557.14%)
Mutual labels:  console
Mitype
Typing speed test in terminal
Stars: ✭ 241 (+1621.43%)
Mutual labels:  console
Colour Mysql Console
Sample config files showing how to colorize linux console mysql client
Stars: ✭ 244 (+1642.86%)
Mutual labels:  console
Consolegameengine
.NET Console Graphics Engine
Stars: ✭ 226 (+1514.29%)
Mutual labels:  console
kube-design
Kube Design for KubeSphere Console
Stars: ✭ 88 (+528.57%)
Mutual labels:  console
Term Sheets
Create animated terminal presentations. Export as SVG, animated GIF, or HTML+CSS
Stars: ✭ 243 (+1635.71%)
Mutual labels:  console
Wpm
Typeracer-like console app for measuring your WPM
Stars: ✭ 249 (+1678.57%)
Mutual labels:  console
Webpack Messages
Beautifully format Webpack messages throughout your bundle lifecycle(s)!
Stars: ✭ 238 (+1600%)
Mutual labels:  console
Chroma
A general purpose syntax highlighter in pure Go
Stars: ✭ 3,013 (+21421.43%)
Mutual labels:  console
Sc Im
sc-im - Spreadsheet Calculator Improvised -- An ncurses spreadsheet program for terminal
Stars: ✭ 3,081 (+21907.14%)
Mutual labels:  console
Text Io
A library for creating interactive console applications in Java
Stars: ✭ 229 (+1535.71%)
Mutual labels:  console
Terminal
The new Windows Terminal and the original Windows console host, all in the same place!
Stars: ✭ 79,371 (+566835.71%)
Mutual labels:  console
Rxterm
Functional reactive terminals in C++ ⚡⌨️
Stars: ✭ 226 (+1514.29%)
Mutual labels:  console
Asciimatics
A cross platform package to do curses-like operations, plus higher level APIs and widgets to create text UIs and ASCII art animations
Stars: ✭ 2,869 (+20392.86%)
Mutual labels:  console
capybara-chromedriver-logger
Enables console.log/error/info output from Javascript feature specs running with Chromedriver
Stars: ✭ 54 (+285.71%)
Mutual labels:  console
GetConsoleHistoryAndOutput
An Incident Response tool to extract console command history and screen output buffer
Stars: ✭ 41 (+192.86%)
Mutual labels:  console
Finalcut
A text-based widget toolkit
Stars: ✭ 244 (+1642.86%)
Mutual labels:  console

PELT TESTING

Pelt is a library for testing your algorithms and generate various data type for these algorithm of differents ways.

INSTALLATION AND IMPORTATION:

pip install pelt-testing

from pelt import Pelt

Contents:


Basics

One of functionalities of Pelt, is evaluate your algorithm with differents types of tests. Among they are evaluate the type of data, the expected value, if two tests are same type, among others.

Help

This function provides a summary of all the methods that Pelt has.

Example:

Pelt.help()

Output:

Pelt Help

Test

This function represent a unit test, it's the more basic functionality in Pelt.

Params: test( function, expected value, optional text)

Pelt.test(10 + 5, 15)

Output: UNIT TEST [🕙 66275899.9337248]
        Success Test
        Expected Value: 15
        Ouput: 15 🥇

Pelt.test(sum( 20,20 ), 40)

Output: UNIT TEST [🕙 66275899.9337248]
        Success Test
        Expected Value: 40
        Ouput: 40 🥇

Pelt.test(sum( 25,10 ), 30)

Output: UNIT TEST [🕙 66275899.9337248]
        Success Test
        Expected Value: 30
        Ouput: 35 💥 

Per default, test() add a example text for your unit test, but also you can add a own text.

Pelt.test(mult( 2,10 ), 20,"Multiplication")

Output: MULTIPLICATION  [🕙 66275899.9337248]
        Success Test
        Expected Value: 20
        Ouput: 20 🥇

Describe

This function represent a group of unit tests, it prints a detailed feedback of this tests group Per default it add a example test, but also you can add a own text.

Params: describe( matrix, optional text)

Pelt.describe((
    ( sum(10,20),30 ),
    ( sum(20,20),40, "SUM OF NUMBERS" ),
    ( sum(25,25),55, "INCORRECT SUM OF NUMBERS" ),
),"SUMS")

Ouput: 🔍 SUMS 🔎

        UNIT TEST [🕙 61346599.9386544]

        Success Test 
        Expected Value: 30
        Ouput: 30 🥇
        ➖➖➖➖➖➖➖➖

        SUM OF NUMBERS [🕙 62347999.937653]

        Success Test
        Expected Value: 40
        Ouput: 40 🥇
        ➖➖➖➖➖➖➖➖

        INCORRECT SUM OF NUMBERS [🕙 63402799.936598]

        Failed Test
        Expected value: 55
        Ouput: 50 💥
        ➖➖➖➖➖➖➖➖

Without own text and with matrix:

Pelt.describe([
    [ sum(5,5),10 ],
    [ sum(13,12),25, "SUM OF NUMBERS" ]
])

Ouput: 🔍 TESTS GROUP 🔎

        UNIT TEST [🕙 81670499.918331]

        Success Test
        Expected Value: 10
        Ouput: 10 🥇
        ➖➖➖➖➖➖➖➖

        SUM OF NUMBERS [🕙 83254399.9167468]

        Success Test
        Expected Value: 25
        Ouput: 25 🥇
        ➖➖➖➖➖➖➖➖

Is_equal

It compare the type and the value of the two tests introduced, something examples below.

Params: is_equal( test1, test2 )

Pelt.is_equal(10, 10)

Output: ❕ ---TEST COMPARISON---10 AND 10 ARE EQUAL 🥇
        10 :: <class 'int'>
        10 :: <class 'int'>

Pelt.is_equal("Javascript","Java")

Ouput:  ❕ ---TEST COMPARISON---Javascript AND Java NOT ARE EQUAL 💥
        Javascript :: <class 'str'>
        Java :: <class 'str'>

Pelt.is_equal(10,"10")

Output: ❕ ---TEST COMPARISON---10 AND 10 NOT ARE EQUAL 💥
        10 :: <class 'int'>
        10 :: <class 'str'>

Pelt.is_equal( [10,20,30],[10,20,"30"] )

Output: ❕ ---TEST COMPARISON--- ❕

        [10, 20, 30] AND [10, 20, '30'] NOT ARE EQUAL 💥
        [10, 20, 30] :: <class 'list'>
        [10, 20, '30'] :: <class 'list'>

Not_is_equal

Contrary to is equal, this function evaluates if the two tests are not of the same type and value.

Params: not_is_equal( test1, test2 )

Pelt.not_is_equal([10,20,30],[10,20,"30"])

Ouput:  ❗ ---TEST COMPARISON--- ❗

        [10, 20, 30] AND [10, 20, '30'] NOT ARE EQUAL 🥇
        [10, 20, 30] :: <class 'list'>
        [10, 20, '30'] :: <class 'list'>

Pelt.not_is_equal(10,10)

Ouput:  ❗ ---TEST COMPARISON---10 AND 10 ARE EQUAL 💥
        10 :: <class 'int'>
        10 :: <class 'int'>

Is_equal_type

It compare only the data type between the two tests introduced, In this case the value of data not is important, something examples below.

Params: is_equal_type( test1, test2 )

Pelt.is_equal_type(10,5)

Output: ❕ ---TEST TYPE COMPARISON---10 AND 5 ARE THE SAME TYPE 🥇
        10 :: <class 'int'>
        5 :: <class 'int'>

Pelt.is_equal_type("10",10)

Output: ❕ ---TEST TYPE COMPARISON---10 AND 10 NOT ARE THE SAME TYPE 💥
        10 :: <class 'str'>
        10 :: <class 'int'>

Pelt.is_equal_type("JS","Javascript")

Output: ❕ ---TEST TYPE COMPARISON---JS AND Javascript ARE THE SAME TYPE 🥇
        JS :: <class 'str'>
        Javascript :: <class 'str'>

Not_is_equal_type

Contrary to is equal type, this function evaluates if the two tests are not of the same type, the data value not is important.

Params: not_is_equal_type( test1, test2 )

Pelt.not_is_equal_type(10, 10)

Output: ❗ ---TEST TYPE COMPARISON---10 AND 10 ARE THE SAME TYPE 💥
        10 :: <class 'int'>
        10 :: <class 'int'>

Pelt.not_is_equal_type((1,4,5), [10,"GO"])

Output: ❗ ---TEST TYPE COMPARISON--- ❗

        (1, 4, 5) AND [10, 'GO'] NOT ARE THE SAME TYPE 🥇
        (1, 4, 5) :: <class 'tuple'>
        [10, 'GO'] :: <class 'list'>

Is_type

It evaluate the type of value of your data or your test.

Params: is_type( value )

Pelt.is_type( (1,4,5) ) 

Output: ❕---VALUE TYPE--- ❕

        (1, 4, 5) ⇔ 'tuple'

Pelt.is_type( sum(10,20) )

Output: ❕---VALUE TYPE---30'int'

Pelt.is_type( {"5",4,5} )

Output: ❕---VALUE TYPE--- ❕ 

        {'5', 4, 5} ⇔ 'set'

Is_none

It evaluate if your test is none or not.

Params: is_none( test )

Pelt.is_none( sum(10,20) )

Output: ❕---TEST NONE---NOT IS NONE 💥

Pelt.is_none( None )

Output: ❕---TEST NONE---IS NONE 🥇

Generators

Pelt also offers various types of test data generators for you to test your algorithms and evaluate the result with the data that can be found in Pelt. This will prevent you from generating data manually and repetitively.

Gt_int

This method generates a random number between 0 and 300, this method can take a number as a parameter. If you pass a number as a parameter, this method will return you an array of numbers with the length of the parameter you added.

Params: gt_int( number ), per default it is 1

> print( Pelt.gt_int() )

Output: 254

> print( Pelt.gt_int(5) )

Output: [162, 13, 16, 15, 106]

> number_list = Pelt.gt_int(10)

Output: [242, 275, 211, 105, 58, 40, 201, 281, 28, 38]

Now we are going to use it in our software:

def sum(a,b):
    return a + b, ( a,b ) 

print( sum( Pelt.gt_int(),Pelt.gt_int() ))

Output: (78, (61, 17)) => result: 78, a: 61, b: 17

〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰

def div(a,b):
    return a / b, ( a,b ) 

print( div( Pelt.gt_int(),Pelt.gt_int() ))

Output: (2.456896551724138, (285, 116)) => result: 2.456896551724138, a: 285, b: 116

〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰

def duplicate_list(list):

    duplicate = []
    for i in list:
        duplicate.append( i * 2)

    return duplicate, list

print( duplicate_list( Pelt.gt_int(5) ))

Output: ([416, 226, 362, 296, 512], [208, 113, 181, 148, 256])

〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰

>> More Advance 

def duplicate_list(list):
    
    duplicate = [ i * 2 for i in list]

    return duplicate, list

print( duplicate_list( Pelt.gt_int(12) ))

Output: ([396, 154, 354, 530, 224, 480, 192, 196, 180, 452, 120, 24], [198, 77, 177, 265, 112, 240, 96, 98, 90, 226, 60, 12])

〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰

number_list = Pelt.gt_int(4)

print( list( map( lambda x: x * 2, number_list )), number_list )

Output: [330, 142, 180, 564] [165, 71, 90, 282]

Gt_str

It has a similar behavior to gt_int, basically its difference It is that this function generates a string randomly and gt_int an integer.

Params: gt_str( number ), per default it is 1

> print( Pelt.gt_str() )

Output: injected

> print( Pelt.gt_str(4) )

Output: ['Lorem', 'qwertyuytr', 'p', 'occaecat']

〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰

def inject_py(string):

    return "{}py ".format( string ) 

print( inject_py(Pelt.gt_str()) )

Output: nullapy 

〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰

def duplicate_string(string):

    return list( map(lambda x: x * 2,string) ) 

print( duplicate_string(Pelt.gt_str(4)) )

Output: ['IpsumIpsum', 'consecteturconsectetur', 'fugiatfugiat', 'injectedinjected']

Gt_mix

As its name implies, mix returns a number or a string randomly. If you pass a number as a parameter, it can return an list with numbers and strings.

Params: gt_mix( number ), per default it is 1

> print( Pelt.gt_mix() )

Output: 248

> print( Pelt.gt_mix(5) )

Output: ['since', 'standard', 267, 285, 'Excepteur']

Remember, you can combine generators with tests:

# As the tests have return a print built in, it is not necessary to put them in your function

def type_data(data):

    return Pelt.is_type(data)

type_data( Pelt.gt_mix() )

Output: ❕---VALUE TYPE---Latin'str'

〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰〰

def equal_values(value1,value2):

    return Pelt.is_equal_type(value1,value2)

equal_values( Pelt.gt_mix(),Pelt.gt_mix() )

Output: ❕---TEST TYPE COMPARISON---PowerUp AND 169 NOT ARE THE SAME TYPE 💥
        PowerUp :: <class 'str'>
        169 :: <class 'int'>

Gt_dict

This generator return a random dictionary with random keys and values, per deafult not return nested dictionaries, but you can custom the dictionarys combining the others generators.

Params: gt_dict( number ), per default it is 1

> print( Pelt.gt_dict() )

Output: {'looks': 155}

# You can also create a custom dictionary, depending on your need.

multy_dict = {
    Pelt.gt_str(): Pelt.gt_mix(5)
}

> print(multy_dict)

Output: {'looks': ['words', 5, 115, 102, 'PowerUp']}

multy_dict = {
    Pelt.gt_int(): Pelt.gt_dict(4), 
    Pelt.gt_str(): Pelt.gt_str(5)
}

> print(multy_dict)

Output: {22: {296: 'dolor', 'qwertyuytr': 298, 75: 'standard', 'words': 'p'}, 
        'Ors': ['PowerUp', 'Finibus', 'injected', 'fugiat', 'therefore']}

Gt_set

This generator return a random set, it has a similar behavior that the others, some examples below:

Params: gt_set( number ), per default it is 1

> print( Pelt.gt_set(5) )

Output: {136, 200, 'Cors-c', 277, 120}

def joiner(value):

    example = {"example",1,2}
    return value.union(example) 

print( joiner(Pelt.gt_set(4)) )

Output: {1, 2, 'ghorlayck', 'example', 201, 283, 'injected'}

Snap

After learning the functionality of the generators, surely you would have liked that said test data could have it in a separate flow to test and to better predict the result of your algorithms. Now we are going to unleash all the power that Pelt can offer, with the snap functions we can archive test data and test it later with a much more predictable result, allowing you to use the tests in a more efficient way.

NOTE: SNAPS ONLY RECEIVE A GENERATORS

Snap_take

This function creates a file with the generated data that you passed to the function, you must pass it the name you want for your file, if you passed it the name of an existing file it will overwrite the data.

Params: Pelt.snap_take( "file name", ( Generators, Generators, ... ) ) => Require a matrix

Pelt.snap_take("Data", (
    Pelt.gt_int(5), Pelt.gt_str(4)
))

Pelt Snap_take

def duplicate(numbers):
    return list(map( lambda x: x *2, numbers))


data = Pelt.gt_int(5)

Pelt.snap_take("Data",(
    duplicate(data), data
))

Pelt Snap_take

Snap_rm

This function creates a file with the generated data that you passed to the function, you must pass it the name you want for your file, if you passed it the name of an existing file it will overwrite the data.

Params: Pelt.snap_rm( "file name" )

Pelt.snap_rm("Data")

It removes a file generate with these name.

Snap_rm_all

This function remove all files generated with snap.

Params: Pelt.snap_rm_all()

Pelt.snap_rm_all()
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].