The correct version of the code we are testing is in a module named piggy. This module simulates a ceramic piggy bank. It works like this: initially it starts off containing no coins and having no value. As you add coins, the number of coins in the bank increases, and also the total value of the coins increases. Of course, it is limited in size, so there is a maximum number of coins it can hold (we are assuming that all coins take up the same space regardless of their value). Once it reaches that maximum, you can't add any more. Finally, it can be smashed to get the money out. But after it is smashed, it contains no coins and you can't add any more, until you re-initialize the module by calling start again.
The correct version of the code we are testing is in a module named piggy. This module simulates a ceramic piggy bank. It works like this: initially it starts off containing no coins and having no value. As you add coins, the number of coins in the bank increases, and also the total value of the coins increases. Of course, it is limited in size, so there is a maximum number of coins it can hold (we are assuming that all coins take up the same space regardless of their value). Once it reaches that maximum, you can't add any more. Finally, it can be smashed to get the money out. But after it is smashed, it contains no coins and you can't add any more, until you re-initialize the module by calling start again.
The module has the following functions:
start(max) - initializes the piggy bank so it can hold the given maximum number of coins. Initially it contains no coins and has zero value and is not smashed.
add_coin(coin_value) - adds a coin with the given value to the piggy bank, unless it is full or smashed. The coin value can be anything
get_value() - returns the total value of all the coins in the piggy bank
get_num_coins() - returns the total number of coins in the piggy bank
smash() - smashes the piggy bank, after which it has no coins and no coins can be added
For example, we should be able to write code like this:
import piggy as p # initialize the piggy bank to have a capacity of 5 coins p.start(5) print(p.get_num_coins()) # expected 0 print(p.get_value()) # expected 0 # add a couple of coins p.add_coin(10) p.add_coin(25) # check what we've got print(p.get_num_coins()) # expected 2 print(p.get_value()) # expected 35
Bad piggies
There are also six implementations of the piggy bank specification that have errors in the code, named piggy1 through piggy6. Your task is to write a set of test cases, similar to the ones above, so that the original piggy module passes all your tests, but each of piggy1 through piggy6 fails at least one of your test cases.
To simplify the whole process of testing and checking, we are going to do two things
- Notice the form of the import statement above. Instead of
import piggy
we write
import piggy as p
Then, we can refer to the piggy module simply as p throughout our code. The advantage of this is that we can test a different module just by changing the import.
- Use a helper function to check whether we're getting correct values. Instead of simply printing the output as above, and then having to carefully read it to see if it's correct, we'll just pass the value we expect into the helper function to be checked, along with a description of what we're testing.
Take a look at the template in the code editor below, and try running it (in "Develop" mode). Then, modify the import statement:
import piggy1 as p
and run it again. Notice it is obvious that piggy1 has a bug, since the actual value returned by getValue doesn't match the expected. value 35.
Value after add_coin(25): expected 35, found 25
Please solve in python :)
Step by step
Solved in 2 steps with 1 images