Blog

MockBox 1.3 Released

Luis Majano December 12, 2010

Spread the word

Luis Majano

December 12, 2010

Spread the word


Share your thoughts

After much inspiration during long baby duty nights, we bring you today MockBox version 1.3.  This release sports a revamp of the entire documentation structure both on the wiki and internally in the API.  This was a huge ticket for me, as I wanted to make the introduction into mocking and unit testing a little bit easier.  So hopefully, this will help out all you curious folks who want to venture down into MockLand!  So let's review it:

So we already said the documentation and API docs are brand new, great! So what else:
  • coldbox-1057 mocking argument normalization, diff expectations when name-value or positional argument calling.  This means that you can test with ordered or name-value pairs or even argument collections and MockBox will determine the right matching values for you.  If you are new to MockBox, don't worry, this was a cool fix to how MockBox matches arguments to results.
  • coldbox-1144 change all mock methods to their $ name equivalents on the MockBox CFC so they are documented like so.  This was not the case on version 1.2 where we created method aliases, this just added overhead and not a very clear mocking API.  So this was revamped and I documented the functions out of it.

New Verification Methods


Unit testing and mocking cannot be possible without behavior verification, so we expanded our mocking language to include several new methods to help you verify when these mocked methods are called.  Also remember that MockBox has call logging integrated so it can keep track of method calls and their real arguments, so you can assert them later via the $callLog() method.


$verifyCallCount becomes $times()


This is just an alias, but it is way shorter and more meaningful, which basically let's you find out how many times ALL mocked methods have been called on a target, or if you pass in the method name as an argument, then only the times that specific method was called.


$atMost() and $atLeast()



These verification methods allow you to track the minimum and maximum times ALL mocked methods have been called or if you pass in the method name, the specific method.  This is great to achieve minimum number or maximum number of calls to a specific method have to be made and then asserted.


$never() and $once()


These are great shortcuts to find out if a mocked method or ALL mocked methods have NEVER been called or they have been called exactly one time.


$reset()


This little gem provides you with a way to reset all method call counter and call loggers so you can start fresh and mock again!


This concludes our 1.3 release. We have lots of great ideas for our next version MockBox 2.0 which will includes some awesomeness when it comes down to expectations, verifications and behavior. We are already planning several features that will allow you to verify when methods with specific arguments have been called, create literal arguments instead of data, mock network failures and much more. So get ready to start working in MockLand, it truly is great to Mock!

Add Your Comment

Recent Entries

12 Days of BoxLang - Day 4: TestBox

12 Days of BoxLang - Day 4: TestBox

Today we’re celebrating one of the most exciting new additions to the BoxLang ecosystem:

the TestBox BoxLang CLI Runner — a fast, native way to run your TestBox tests directly through the BoxLang Runtime. ⚡

No server required. No CommandBox needed. Just pure, ultra-fast BoxLang-powered testing from the command lineon Windows, Mac, and Linux.

If you’re building modern applications with BoxLang — web apps, CLIs, serverless functions, Android apps, or OS-level utilities — this new feature gives you a unified, flexible testing workflow you can run anywhere.

Victor Campos
Victor Campos
December 13, 2025
12 days of BoxLang - Day 3: SocketBox!

12 days of BoxLang - Day 3: SocketBox!

As BoxLang continues evolving into a modern, high-performance, JVM-based runtime, real-time communication becomes essential for the applications we all want to build: dashboards, collaboration tools, notifications, live feeds, multiplayer features, and more.

That’s where SocketBox steps in — the WebSocket upgrade listener built to work seamlessly with CommandBox and the BoxLang MiniServer. ⚡

Today, for Day 3, we’re highlighting how SocketBox supercharges BoxLang development by giving you fast, flexible, and framework-agnostic WebSocket capabilities.

Maria Jose Herrera
Maria Jose Herrera
December 12, 2025
12 Days of BoxLang - Day 2: CommandBox

12 Days of BoxLang - Day 2: CommandBox

BoxLang + CommandBox: The Enterprise Engine Behind Your Deployments

For Day 2 of our 12 Days of Christmas series, we’re diving into one of the most powerful parts of the BoxLang ecosystem: CommandBox the defacto enterprise servlet deployment platform for BoxLang.

If BoxLang is the language powering your applications, CommandBox is the engine room behind it all. ⚙️

Victor Campos
Victor Campos
December 11, 2025