Search⌘ K
AI Features

Testing Specials

Explore how to test special pricing scenarios in property-based testing using PropEr. Understand how to build dynamic generators for regular and special items, merge them, and validate expected prices with consistent and predictable test cases.

Getting started

Rather than modifying the existing property, which does a fine job of checking non-special prices, we’ll add a new one to check specials. The separation will help narrow down problems when they happen. If the property for basic prices always works, then we’ll know that failures in the separate special property likely relate to bugs in the special one’s handling.

Let’s take a look at the property that we could implement.

property "sums including specials" do
  forall {items, expected_price, prices, specials}
          <- item_price_special() do
    expected_price == Checkout.total(items, prices, specials)
  end
end

This property is similar to the one we wrote earlier, except that we now expect another term out of the generator, which is a list of special prices, specials in Elixir. The easiest way to go about this would be to just come up with a static list of specials and then couple it with the previous property’s generator, but that wouldn’t necessarily exercise the code as well as fully dynamic lists, so let’s try to do that instead.

Planning the generators

First things first, we’ll need the basic list of items and prices. For that, we can reuse the price_list() generator, which gives us a fully dynamic list. Then, if we want the specials list to be effective, we should probably build it off the items in the ...