Jump to content
Xtreme .Net Talk

Recommended Posts

Posted

I'm currently working on a command line tool that I would like to automate tests for -- basically I need to run some functional/integration tests on the entire tool and I don't have a lot of money to spend.

 

The options I've come up with so far:

-- Use NUnit to run the tests -- I would probably invoke the tool programmatically, capture output, and verify the results (both printed and functional)

-- Hand roll tests using a light weight scripting language such as Ruby or PowerShell.

 

Both of these cases really amount to the same thing -- in one I can start writing tests immediately, the other I have to do a little more work up front to figure out how it will all come together. The huge negative to both of these is that I will have to build extra functionality in to keep the tests easily adaptable to changes over time. They both feel kind of clunky to me and I would end up having to maintain not only the tests, but also the testing tool/scripts.

 

Does anyone know of a free/open source tool that does this kind of testing? I suppose it really doesn't need to be .Net specific as I'll be running the tool externally.

Posted (edited)
I found what I was looking for. FIT is pretty much the de facto standard it seems and I must say, after playing with it for a few hours, it will blow your mind with its awesomeness. :cool: It is very cool. Edited by mskeel
Posted

never had the time nor the need (so far) to look at http://fitnesse.org/

hmm....fit...fitnesse ....? is it the same:

 

"Great software requires collaboration and communication. Fit is a tool for enhancing collaboration in software development."

 

"Great software requires collaboration and communication. FitNesse is a tool for enhancing collaboration in software development."

Debug me...
Posted (edited)

As it turns out, FitNesse is a wiki front end for a heavily modified version of FIT which is kind of ironic because FIT was created by Ward Cunningham, the father of the Wiki. FitNesse eventually lead me to FIT. Sometimes it's just a matter of finding the right vocabulary so you can go off and figure it out for yourself, which can be hard when you're first starting out in a new problem domain.

 

FIT has been pretty cool so far. All the tests are stored in human readable HTML which can make up your specification document. It makes it really easy for you or your client or a subject matter expert to modify, run, and understand the tests. You even get a green/red pass/fail report using the same template as the spec so you know exactly what is working and what isn't -- right now. All the test criteria are stored externally and there is a minimum amount of code necessary to put the hooks into your program. This addresses two of my biggest concerns with rolling my own solution.

 

For my project, I checked the FIT executable and library (for creating test fixtures) into version control so now other members of my team can easily run acceptance tests right out their sandbox without having to install and configure additional scripting languages or software that they may not have currently on their machines (powershell is still just a release candidate I believe).

 

Also, here is a good example of how FIT is used. Just ignore the little tool the author wrote. It sounds cool but it actually really sucks. Of particular interest in this article are the differences between acceptance testing and unit testing (the author�s a fan of NUnit too).

 

I'm telling you, this stuff will explode your brain with it's awesomeness..

Edited by mskeel

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...