Exploding Link Stubs in C 55

Posted by Michael Feathers Sat, 08 Nov 2008 01:33:00 GMT

When you’re working in a batch of legacy C code, it’s often hard to build and test just a part of it. You may want to build some set of functions, but then you discover that they call other functions, and those functions call yet other functions. When link dependencies are very bad, you may discover that you’re linking in the entire system.

Fortunately, there is a way out of this. Pick a set of files that appear to be a “component” and attempt to build them into an executable along with a simple main function.

You will get link errors.

Create a file called <componentname>_stubs.c and then go through each of the link errors. Look up the full declaration of the variable or function the error describes. Create a stub for each of them in the stub file.

Here’s an example of a function stub:


int irc_send_ppr(struct ppr *pprn, int nSize)
{
}

The only problem with this is that you have to place something in the stub function. For functions which return values you need to, at the very least, provide a return value. But what should it be?


int irc_send_ppr(struct ppr *pprn, int nSize)
{
  /* is negative -1 okay?   If it isn’t, how will we know? */
  return -1;
}

There is alternative ++:


int irc_send_ppr(struct ppr *pprn, int nSize)
{
  assert(!”irc_send_ppr boom!!”);
}

This is an exploding link stub. When you have it in place, you will know when a function you’re testing calls a stub. When you see the boom you go to the code and replace the assert with a better stub implementation.

When you use link stubs, you have to be able to build your component two different ways. Production builds link to the rest of the code. Test builds link to the stubs and a testing main. There’s no need to stub out all of the external functions that a component uses. Many low level functions can remain direct calls, but stubbing out calls to other high level components can give you a decent amount of leverage as you try to get an area under test.

Fortunately, for any given component you only have to go through the massive grunt work once. Once you do, you can reap the reward of easier testing in that component forever.

++ Note: If you are using C99, you can genericize this code by using the __func__ predefined macro. In any function, __func__ expands to the name of the enclosing function.

Comments

Leave a response

  1. Avatar
    Anonymous about 2 hours later:

    If you are using any modern C or C++ compiler, you can genericize this code by using the non-standard but universally supported keyword FUNCTION. In any function, FUNCTION expands to the name of the enclosing function, just like func, but in the form of a string literal ready for string concatenation. (C99’s func keyword is not a macro, and does not expand to a string literal so it cannot be concatenated with adjacent strings.)

    #define EXPLODE assert(!”Boom in ” FUNCTION);

  2. Avatar
    Sam about 9 hours later:

    Actually, to make this really easy, you don’t need to get the right types. Your C compiler/linker will give you a list of undefined dependencies. You can then use some sed/awk/perl/whatever magic to transform this into a C file that will solve these. All you need to do is generate a file like this:

    #define STUB(x) void x(void) { assert(0 && "Undefined function " __func__); }
    
    STUB(func1);
    
    STUB(func2);
    

    It doesn’t matter that their signatures aren’t right; the linker only sees them as symbols. I’ve been using this method successfully in my own project where I need to pull code out of a large ecosystem (the kernel) and link it into another.

  3. Avatar
    Michael Feathers about 17 hours later:

    @Anonymous: Thanks. It’s a shame that __func__ is defined the way it is.

    @Sam: Thanks for bringing that up. I’ve done that in the past (and since forgotten about it). Great way to get the initial link. The only thing is, I want to get the real signature in whenever I write a test that explodes a stub. Fair call, though, that you don’t have to do it all at once.

  4. Avatar
    Pete 2 days later:

    The dependency breaking techniques in your book have been great for getting me ‘unstuck’. Thanks!

  5. Avatar
    owbear@gmail.com 3 days later:

    This is Interface Discovery. It can be a very useful way of reasoning about a system—http://connextra.com/aboutUs/mockobjects.pdf

  6. Avatar
    MTS File Converter about 1 year later:

    just have a try

  7. Avatar
    Tech Web about 1 year later:

    I use to read your posts.They’re extremely informative and useful.Many thanks for giving us this kind of quality expertise.Waiting for the following fascinating posts.

  8. Avatar
    latin shoes about 1 year later:

    Most problems happens before testing, nice post anyway!

  9. Avatar
    latin shoes about 1 year later:

    would you mind updating your blog with more information?

  10. Avatar
    jewellery about 1 year later:

    would you mind updating your blog with more information?

  11. Avatar
    yalova emlak about 1 year later:

    Thank you very much for this article.I like its.As to me it’s good job.

  12. Avatar
    fake louis vuitton about 1 year later:

    one day give patients’ bodies louis vuitton ties for men the ability to make the rubber watches missing enzyme. However, gene therapy nike girls trials suffered an enormous blow gucci shoes for women with the death of 18-year-old Hermes Crocodile Jesse Gelsinger, a young man

  13. Avatar
    Pandora over 2 years later:

    you can think of traits as analogous to Java interfaces, but with implementations.

  14. Avatar
    ugeots over 2 years later:

    This is a great inspiring article.I am pretty much pleased with your good work. ugg classic cardy You put really very helpful information. Keep it up. Keep blogging. ugg outlet

  15. Avatar
    http://www.blacktowhiteiphone4.com over 2 years later:

    Apple’s official white iPhone 4 is likely to release untile next year. But in this autumn there’s already got white iphone 4 available.

  16. Avatar
    laptop accessories over 2 years later:

    JAY Follow laptop accessories the detail tips below, you can increase the laptop battery life of a year or more. 1. The laptop battery first thing you should care about the

  17. Avatar
    Beacher over 2 years later:

    When link dependencies are very bad, you may discover that you’re linking in the entire system.

  18. Avatar
    Disount Christian Louboutin over 2 years later:

    This is a superb posting, I identified your weblog web page executing study google for any related topic and came to this. I never thought I would agree with this opinion, but I’m starting to view things from a different view. I have to research more on this as it seems very interesting. I couldnt uncover to substantially supplemental info and details on this write-up, so it was pleasant to find this 1. I’ll in all probability finish up currently being again once more to appear at another content articles that you’ve got yet another time. yhm20110408 Disount Christian Louboutin

  19. Avatar
    James Aaron over 2 years later:

    It is another informative post. I like it. Thanks. roofing venice

  20. Avatar
    okey oyunu oyna over 2 years later:

    your post is useful for us. Thanks

    internette görüntülü olarak okey oyunu oyna, gerçek kisilerle tanis, turnuva heyecanini yasa.

  21. Avatar
    real estate advertising over 3 years later:

    Thank you for blog I read it always :-)

  22. Avatar
    Monster Beats By Dr. Dre Studio over 3 years later:

    The Monster Beats By Dr. Dre Studio Headphones are classic shoes.You will be proud of owning them. Don’t hesitate!Take Monster Beats By Dr. Dre Pro home!

  23. Avatar
    christian louboutin shoes on sale over 3 years later:

    Have the christian louboutin patent leather pumps is a happy thing.

  24. Avatar
    Tiffany Sale over 3 years later:

    We’ve go through your own exceptional blog which posting on-line, have numerous good friends combined with me to examining your own article content. Whatever we are, as well as whatever we would like, the principle concept you’ve recently been displayed was satisfied by us. Thanks much for sharing so perfect point of view, and it create us get a feeling of relaxed and ease.

  25. Avatar
    http://www.essay-service.org/research-paper over 3 years later:

    When I see a lot of methods and C codes It’s hard for me to understand some codes. That’s an example of me interpreting without reading. You have to analyse that thoroughly and quickly.

  26. Avatar
    http://www.essay-service.org/research-paper over 3 years later:

    When I see a lot of methods and C codes It’s hard for me to understand some codes. That’s an example of me interpreting without reading. You have to analyse that thoroughly and quickly.

  27. Avatar
    christianlouboutin over 3 years later:

    All among us realise that if you MBT boots or shoes within get hold of, Jimmy Choo Sandaleseducation-women’ vertisements mbt tunisha providing may easily really encourages lymphatic circulation,Jimmy Choo Bottines you’ chemical in all probability more significant receive boots or shoes clearance retail store as a result of MBT while it a good number of at no cost submitting in combination with MBT boots or shoes are almost always pay for and also profit designed notnaxcanada goose outlet.

    A particular low-priced MBT Nama Boots and shoes out of a number of online space boots and shoes plus boot footwear MBT great bargains preferred now in now would be to simply and even safely mbt sandals pay for consumers pay for progressively more over the internetcanada goose jakke, have MBT footwear and remaining grown to be a sample. MBT boots providing now, ways to explain any one prevent
    the north face

    ? Brand-new assumed to test a person's MBT boots pay for, generate a test? My wife and i reassurance any one, we have a special working experience
    North Face Denali Jakker Kvinder hoodie

    .
  28. Avatar
    DR OZ african Mango over 3 years later:

    When I at first left a comment I clicked the “Notify me when new comments are added” checkbox and now each time a comment is added I get three notification emails with the same comment. Is there any way you can take away people from that service? Thanks a lot!

  29. Avatar
    Tory Burch outlet store over 3 years later:

    It’s great when you find relevant content .I can’t stay without admiring your post its really awesome thanks for sharing such a nice content.

  30. Avatar
    <a href="http://executivedirectorjobdescription.org/ ">Executive Director Job Description</a> over 3 years later:

    This is very much impressed with the great services in this blog that to using the great technology in this blog. I am really interesting info is visible in this blog that to sharing the great services in this blog that to using the great services in this blog. This is very much impressed with the great technology is visible in this blog that to sharing the great services in this blog Executive Director Job Description| General Manager Job Description| Consultant Job Description Webmaster Job Description

  31. Avatar
    anji843 over 3 years later:

    This is very much enjoyed for the great services in this website. I am very much happy for providing the great technology is visible in this website that to using the great services in this blog Webmaster Job Description

  32. Avatar
    Discount Gucci Sale over 3 years later:

    Just want to say what a great blog you got here!I’ve been around for quite a lot of time, but finally decided to show my appreciation of your work!

  33. Avatar
    Tips For Bowling over 3 years later:

    People were so keen to get investment. In those days, there was quite significant unemployment in Northern Ireland, and that had been the general pattern in Northern Ireland for many, many years. John Hume

  34. Avatar
    alwadifa over 3 years later:

    I liked you blog so im going bookmark it with my prefered websites, you have posted an amazing posts so thank you I liked you blog so im going bookmark it with my prefered websites, you have posted an amazing posts so thank you

  35. Avatar
    write writer over 3 years later:

    I learned something new just by trying your codes and tweaking them just a little bit, it was really all a good help, thanks for those info and kudos!

  36. Avatar
    grad school personal statement over 3 years later:

    Thank you for the efforts you been putting on making your site such an interesting and informative place to browse through. I’ll be visiting your site again to gather some more valuable information.

  37. Avatar
    iphone contacts backup over 3 years later:

    explore a way to backup iPhone contacts

  38. Avatar
    sallyerma over 3 years later:

    I have been searching all over the blogs for a relevant article related to this topic for a paper I am writing. I’ll be sure to come back to your blog for other valuable information next time I need solid information on this subject. layered hairstyles

  39. Avatar
    Microsoft Office over 3 years later:

    This article is GREAT it can be EXCELLENT JOB and what a great tool!

  40. Avatar
    ralph lauren over 3 years later:

    Siècle Série classique américain de los angeles marque Ralph Lauren hommes d’hiver communiqué de 2012, los angeles principale saison des longues de design guy cuir, créateurs intelligents ajouté fermeture éclair dans los angeles couche moyenne de cuir, veste durante cuir cuando longtemps devient instantanément courtroom. Los angeles couleur beige et noir également, put créer united nations design parfait guy scandinaves.http://www.vetementpoloralphlauren2012.net

  41. Avatar
    Easy to do hairstyles over 3 years later:

    This article is GREAT it can be EXCELLENT JOB and what a great tool!

  42. Avatar
    short hairstyles for women over 3 years later:

    “It is perfect time to make some plans for the future and it’s time to be happy. I have read this post and I really really like the topic about gadgets. “

  43. Avatar
    mbtshoe over 3 years later:

    Australia Beats By Dre Studio dr dre beats headphones beats studio beats pro beats solo hd pro headphones music Official store Monster Beats By Dre Pro

  44. Avatar
    celebrity gossip over 3 years later:

    I’ll be visiting your site again to gather some more valuable information.

  45. Avatar
    short hairstyles for women over 3 years later:

    Thanks for taking this opportunity to converse about this, I feel fervently about this and I like learning about this subject. Please, as you gain facts, please update this blog with more information. I have found it extremely useful.

  46. Avatar
    best short haircuts 2012 over 3 years later:

    I like very much your way of presentation.. I got more useful information on this blog.. Thanks to sharing the useful information….

  47. Avatar
    bladeless fans over 3 years later:

    Exploding Link Stubs in C 46 good post24

  48. Avatar
    louboutin sales over 3 years later:

    Exploding Link Stubs in C 47 hoo,good article!!I like the post!93

  49. Avatar
    desktop wallpaper over 3 years later:

    I like very much your way of presentation.. I got more useful information on this blog.. Thanks to sharing the useful information….

  50. Avatar
    Writing Blog over 4 years later:

    I’ve been visiting your blog for a while now and I always find a gem in your new posts. Thanks for sharing

  51. Avatar
    Christian Louboutin sale nyc over 4 years later:

    Finding the perfect pair of mens shoes for casual wear Christian Louboutin sale nyc often turns out to be a very tedious job. Still, it Christian Louboutin silver peep toe pumps is one of the important aspects, if you really want Christian Louboutin slingback pumps to look fashionable. Here are few wisdom to assist you in the task.

  52. Avatar
    Christian louboutin Miami over 4 years later:

    Wings headset stand out at the end of the party, we put on this pair of wings headphones. It can make head “long” a pair of Christian louboutin Miami, let you absolutely become PROM queen.

  53. Avatar
    hermes gris tourterelle over 4 years later:

    Purses and bags are some of the most famous accessories for women?

  54. Avatar
    cosplay outfits costumes over 4 years later:

    http://www.outfitscosplay.com/cosplay-catalog/devil-may-cry-cosplay Deluxe Devil May Cry Cosplay Costumes for Sale.Find your favorite characters and cosplay outfits from all the popular anime and games.

  55. Avatar
    Mold Making over 4 years later:

    With more than 20 years of experience, Intertech provides an extensive integrated operational ability from design to production of molds 100% made in Taiwan. Additional to our own mold making factory, we also cooperate with our team vendors to form a very strong working force in Taiwan.

    For the overseas market, we work very closely with local representatives in order to take care of the technical communication and after-sales service to our customers. We also participate in the EUROMOLD & FAKUMA exhibitions and meet our customers every year in Europe. By concentrating on mold “niche markets”, we play a very useful mold maker role from the Far East whenever customers want to develop their new projects. We provide services from A to Z to our customers on a very economic cost and effect basis.

Comments