Hello alchemists!
Tests are supposed to be readable/maintainable as every code should be in a perfect world. And explicitness is a good thing for readability.
Beginning my “one kata per day”, I wrote FizzBuzz tests in two ways. I don’t really know which style I prefer: one is very explicit and less concise. The other one is more in a DRY style.
What’s your opinion about this?
Version 1:
defmodule Kata.FizzBuzz.Test do
use ExUnit.Case
import Kata.FizzBuzz
test "1, 2, 4, 7, 8 returns number as a string" do
assert fizz_buzz(1) == "1"
assert fizz_buzz(2) == "2"
assert fizz_buzz(4) == "4"
assert fizz_buzz(7) == "7"
assert fizz_buzz(8) == "8"
end
test "3, 6, 9, 12 returns Fizz" do
assert fizz_buzz(3) == "Fizz"
assert fizz_buzz(6) == "Fizz"
assert fizz_buzz(9) == "Fizz"
assert fizz_buzz(12) == "Fizz"
end
test "5, 10, 20, 25 returns Buzz" do
assert fizz_buzz(5) == "Buzz"
assert fizz_buzz(10) == "Buzz"
assert fizz_buzz(20) == "Buzz"
assert fizz_buzz(25) == "Buzz"
end
test "15, 30, 45, 60 returns FizzBuzz" do
assert fizz_buzz(15) == "FizzBuzz"
assert fizz_buzz(30) == "FizzBuzz"
assert fizz_buzz(45) == "FizzBuzz"
assert fizz_buzz(60) == "FizzBuzz"
end
end
Version 2:
defmodule Kata.FizzBuzz.Test do
use ExUnit.Case
import Kata.FizzBuzz
test "1, 2, 4, 7, 8 returns number as a string" do
[1, 2, 4, 7, 8]
|> Enum.each(fn n -> assert fizz_buzz(n) == "#{n}" end)
end
test "3, 6, 9, 12 returns Fizz" do
[3, 6, 9, 12]
|> Enum.each(fn n -> assert fizz_buzz(n) == "Fizz" end)
end
test "5, 10, 20, 25 returns Buzz" do
[5, 10, 20, 25]
|> Enum.each(fn n -> assert fizz_buzz(n) == "Buzz" end)
end
test "15, 30, 45, 60 returns FizzBuzz" do
[15, 30, 45, 60]
|> Enum.each(fn n -> assert fizz_buzz(n) == "FizzBuzz" end)
end
end