The Artima Developer Community
Sponsored Link

Ruby Buzz Forum
Are your tests findable

0 replies on 1 page.

Welcome Guest
  Sign In

Go back to the topic listing  Back to Topic List Click to reply to this topic  Reply to this Topic Click to search messages in this forum  Search Forum Click for a threaded view of the topic  Threaded View   
Previous Topic   Next Topic
Flat View: This topic has 0 replies on 1 page
Brian Ford

Posts: 153
Nickname: brixen
Registered: Dec, 2005

Brian Ford is Rails developer with PLANET ARGON.
Are your tests findable Posted: Sep 20, 2006 2:54 PM
Reply to this message Reply

This post originated from an RSS feed registered with Ruby Buzz by Brian Ford.
Original Post: Are your tests findable
Feed Title: def euler(x); cos(x) + i*sin(x); end
Feed URL: http://feeds.feedburner.com/defeulerxcosxisinxend
Feed Description: euler(PI) # => -1
Latest Ruby Buzz Posts
Latest Ruby Buzz Posts by Brian Ford
Latest Posts From def euler(x); cos(x) + i*sin(x); end

Advertisement

I probably use Google search on average 20-30 times a day. It’s an indispensable tool for me. It’s definitely not the last word in search engines. I can imagine a lot of additional functionality, like contextualizing my searches over time or within categories. But overall, it works reasonably well.

Lately, I’ve been reading Ambient Findability by Peter Morville. He provides this definition for findability:

findability n
  1. The quality of being locatable or navigable.
  2. The degree to which a particular object is easy to discover or locate.
  3. The degree to which a system or environment supports navigation and retrieval.

Peter explains that findability is defined at both the object and system levels. For example, the title of a document or the color of a pen on your desk. At the system level, you can ask questions like, “Can a traveler navigate an airport,” or “Can a user navigate a website.”

While these ideas help us frame the concepts, how do we evaluate findability in concrete situations. Not surprisingly, there are elements of findability that we can examine:

Findability requires definition, distinction, difference. In physical environments, size, shape, color, and location set objects apart. In the digital realm, we rely heavily on words. Words as labels. Words as links. Keywords.

Hmm, interesting. At PLANET ARGON, we have been evaluating using the rspec_for_rails plugin to focus more heavily on BDD. One of the things BDD emphasizes is leveraging the power of words to help us think more effectively (accurately) about our code. We have been incorporating BDD style method naming into our TDD practices, as well as refining our ability to specify application behavior in our tests.

One thing I dislike about the regular Test::Unit framework is that the methods are often organized ad hoc. Whatever makes the most sense to the programmer when adding those particular tests. Sometimes it’s just appending the method to the list of existing methods. Most often, I notice some sort of organization. Which makes sense; that’s how we deal with information. But the framework doesn’t provide any guidance here.

With the RSpec framework (check out RSpec on Rails), you can arrange your methods into contexts. I think this encourages better organization and contributes to the quality of findability as discussed above. Tests are just another type of information we interact with. How much effort does it take to locate what you’re looking for, understand what the tests are saying, understand the output when a test fails? Following along Jeremy’s questions about acceptable tests:

Are your tests findable?

Read: Are your tests findable

Topic: Feature Ecology Previous Topic   Next Topic Topic: RailsConf Europe wrapup

Sponsored Links



Google
  Web Artima.com   

Copyright © 1996-2019 Artima, Inc. All Rights Reserved. - Privacy Policy - Terms of Use