Slashdot Mirror


Microsoft Vs. TestDriven.NET

Erebus writes "Jamie Cansdale released a free addin to Visual Studio back in 2004 to help developers build unit tests. His only problem was, he enable his addin for all versions of VS - including the Express addition which isn't suppose to support addins. After over a year of trying to talk with Microsoft and understand how and why he was in violation of their license agreement, during which they would never explain specifically which clause in the license was being violated, they sent the lawyers after him and pulled his MVP status. To top it all off, Jamie is actually a Java developer by day — his addin was originally developed just as a hobby project. A full account is available on his blog, including all email correspondence he had with Microsoft and the now 3 letters received from Microsoft lawyers. The lead product manager for Visual Studio Express has responded to Jamie's posts."

11 of 418 comments (clear)

  1. Re:english by DohnJoe · · Score: 5, Funny

    yes, normally this would be flamebait, but this time the English is really too crappy.

    Clearly it was not write by someone who's first language is not english,

  2. But is it illegal? by kebes · · Score: 5, Insightful

    The post from the Visual Studio blog is quite interesting. In the first paragraph, Dan Fernandez says that the add-in "is a direct violation of both the EULA and 'ethos' of the Express product line." Throughout his post, he continually mentions that the add-in is "illegal."

    Yet he spends the entire post talking only about the "ethos" part of it (describing their numerous good faith attempts to convince Jamie Cansdale to stop distributing his product), but he never explains what the illegal part is. Clearly the Visual Studio team feels that Jamie is violating the "ethos" of their project (their "business plan," in fact). On the other hand, Jamie probably feels that the Visual Studio team is violating the "ethos" of his project when they try to limit it. So whose "ethos" is more important?

    At no point, however, does the blog post mention anything about how the Visual Studio EULA could prohibit the distribution of TestDriven.NET. After all, I can redistribute copies of TestDriven.NET without even owning a copy of Visual Studio--so obviously I'm not bound by the Visual Studio EULA.

    I can think of no legal reason to prohibit what Jamie is doing... and apparently, neither can Dan Fernandez. Has anyone found a nugget of legal truth in the other documents?

    1. Re:But is it illegal? by kebes · · Score: 5, Interesting

      Has anyone found a nugget of legal truth in the other documents?
      According to the Microsoft legal threat, the relevant portion of the Visual Studio Express EULA is:

      ...you may use the software only as expressly permitted in this agreement. In doing so you must comply with any technical limitations in the software that only allow you to use it in certain ways... You may not work around technical limitations in the software.
      Microsoft would claim, therefore, that to develop TestDriven.NET, the developer had to download Visual Studio Express, and agree to the EULA in order to install it. However the situation is probably more complex. The issue (from what I can tell) is that a single version of TestDriven.NET works with all versions of Visual Studio (Express or otherwise). So it can easily be shown that TestDriven.NET was developed using the full version of Visual Studio--which not only allows you to create add-ins but in fact encourages you to do so. So the EULA (of the full version of Visual Studio) was not broken.

      So the question is: "Is TestDriven.NET legally required to alter their product so as to enforce the terms of someone else's EULA?" Isn't it the end-user, who combines VS Express and TestDriven.NET that is in violation of the EULA?

      Or perhaps the real question is: "Are ridiculous terms in an EULA, such as 'thou shalt not make the product do things we didn't intend for it to do' actually legally enforceable?"
  3. How far can licenses go by ch-chuck · · Score: 5, Interesting

    I've often wondered how much one can get away with in licenses. Of course they cannot override any consitutional or local laws, but say a developer is rather religious. Can s/he then stipulate that the software cannot be run on Sundays? Or that the user must be wearing underwear or shoes and shirt while using $PRODUCT ?

    --
    try { do() || do_not(); } catch (JediException err) { yoda(err); }
  4. Re:why not? by smittyoneeach · · Score: 5, Insightful
    From the project manager posting:

    extends the Visual Studio Express Editions which is a direct violation of both the EULA and "ethos" of the Express product line.
    Read "ethos" as "business case". MS is using http://en.wikipedia.org/wiki/Market_segmentation. The Express products are a http://en.wikipedia.org/wiki/Gateway_drug to piss you off enough to pony up enough money for the real deal.
    Test Driven Development is not, itself, a bad thing, but if Too Many People glommed onto the underlying technology, and a culture of freedom of expression broke out, well...let us leave the unspeakable unspoken.
    The whole thing is business, pure and simple. If you leave off the 'good' and 'evil' labels, the situation is easier to process.
    Of course, maybe it's all a stealth advertising campaign for http://www.mingw.org/. Who can say?
    --
    Get thee glass eyes, and, like a scurvy politician, seem to see things thou dost not.--King Lear
  5. Re:not to be all nice to microsoft, but by kebes · · Score: 5, Insightful

    If they said 'no addins' for the free edition, and someone does one, surely they are in the right to get annoyed?
    Absolutely. They can get as annoyed as they like. They can yell from the top of a mountain "I am annoyed! Please stop doing that!" In fact that's what they did at first--they tried to convince the developer to stop distributing the project. That's their right.

    However they were not happy with the way the "good faith" negotiations proceeded, and now they are trying to use the law to get their way. The question is, do they have the right to legally enforce their ethos? If there were a contract between Microsoft and TestDriven.NET, then that may limit what TestDriven.NET is allowed to do. However it does not appear that this is the case. In fact, it appears that there is no legal reason why someone can't program add-ins for VS Express. Microsoft may not like it, but it's not illegal. (Please correct me if I'm wrong on that point.)

    If you want to use it, you use it the way they say, that seems obvious to me.
    I disagree. If I obtain a product (buy it for $X or download a free product under certain licensing terms) then I can use it however I want (limited only by the law). If something in the EULA makes it illegal to use add-ins, then I suppose Microsoft can claim that end-users of TestDriven.NET are violating the VS Express EULA... but that still doesn't make TestDriven.NET's actions illegal.

    I have an open source project, and I would get mighty pissed if someone broke my terms. Ok mine are the gpl, but it's the same thing.
    You're mixing two different issues, however. The GPL is a license that (along with copyright) provide a legal framework that delineates what you can and cannot legally do. That is a legal issue. If you release your GPL project, and then find that someone is using your code to run a porn website (but is complying with the GPL), then you may claim that their usage is against the "ethos" of your project--but that still doesn't give you the legal right to prevent their use. You gave them a license to use the software, and that's what they are doing. You can be annoyed, but you cannot sue.
  6. Convenient translation of Fernandez' response by drinkypoo · · Score: 5, Insightful

    However, Jamie has also made available a version of his product that extends the Visual Studio Express Editions which is a direct violation of both the EULA and "ethos" of the Express product line.

    Translation: "Jamie is interfering with our attempt to devalue various Free Software tools."

    It was a small miracle getting Express to be available both for free and for commercial use for customers

    Translation: "Microsoft legal doesn't understand the value of giving away software"

    let alone the engineering work to get it up and running

    Translation: "Our code base is such an encumbered mess that disabling features was an arduous task."

    We made a business decision to not allow 3rd party extensibility in Express. The reason we're able to offer Express for free and even let developers build commercial applications with Express is because we limit 3rd party extensibility of Express, specifically by removing support macros, add-ins, and VSIP packages.

    Translation: "The only way people will buy our crap is if the one feature they need can't be had for free, and their whole product is already implemented using our IDE, making it harder to switch to some other product, perhaps a Free one."

    Unfortunately, in this one instance, we have one company that chose to exceed the license grant and develop additional features into the Express products that are not allowed. Additionally we have over 300 VSIP partners with over 1,000 legal Visual Studio extensions that cannot extend Express.

    Translation: "We decided upon a truly stupid licensing model, and now our customers who paid good money to be able to create extensions are pissed off that we did a shitty job of preventing unlicensed ones from working on a free product."

    It doesn't make business sense when our biggest and best partners are legally unable to extend Express, yet Jamie's company can.

    (No translation needed - it just doesn't make sense! If the extension fits, you must acquit!)

    As for Jamie, we've been asking him in multiple emails and conference calls to stop extending (just Express) since before Visual Studio 2005 even shipped.

    Translation: "Yet almost every time, he has been logical and reasonable, instead of knuckling under."

    [snip]

    We even got the General Manager of Visual Studio to personally talk to him on the phone to plead with him to remove Express extensibility. Closely following that, Jamie took the violations to heart and removed Visual Studio Express extensibility for several months.

    Translation: "But we thought we had him nailed down when we threatened to sow his ground with salt, burn his houses, rape his cattle, and ride off on his women."

    Only recently did he decide to add Express support back to TestDriven.NET and only after another round of conversations and close to two years of trying to avoid escalating this situation, we felt compelled to deliver our message in a different form.

    Translation: "He finally came to his senses and just released the damned thing, so we decided to point more guns at him."

    The vast majority of our customer base, now with 14 million downloads, isn't even professional developers, its non-professionals.

    Translation: "Most people who download this software aren't pros who would pay for our software anyway. In spite of this, I'm so angry I forgot my apostrophe."

    In fact over 80% of Express registrants don't describe themselves as a "developer".

    "They're just people who needed a VS IDE to compile some jackass' project."

    From a total number perspective, beginners are the larg

    --
    "You're right," Fisheye says. "I should have set it on 'whip' or 'chop.'"
  7. More details by Mateo_LeFou · · Score: 5, Interesting

    Digging into the email exchange I found Jamie saying:

    1) You said that by using Intellisense I may be in breach of the
    dissasembly clause in the VS SDK license.
    2) You said that by working out how to use an API by looking at the
    public type and method names I may be in breach of the reverse
    engineering clause in the VS SDK license.
    3) You said that by adding a button to the Express SKU interface I may
    be in breach of Microsoft's copyright.

    #3 is particularly funny

    --
    My turnips listen for the soft cry of your love
  8. Re:Seems fair to me by Anonymous Coward · · Score: 5, Informative

    Microsoft simply responded with "it violates the licence, but we're not going to tell you where."

    Actually they responded with 5 pages of documents stating exactly the clause.

    ("You may not work around any technical limitations in the software.")

    Of course, it's such an incredibly vague sentence one can understand why he didn't think it applied. And I bet they don't want to ever take that one to court, which is whey they had their manager "talk to him on the phone to plead with him".

    Microsoft getting screwed by their own EULA ... sweet, sweet poetic justice.

  9. Re:not to be all nice to microsoft, but by Jaqenn · · Score: 5, Funny

    I commend you for avoiding a car analogy.

    --
    You are awash in a sea of fiercely stated opinions. Obvious exits are: 'File->Quit', 'Reply', and 'Page Down'.
  10. Re:Shoot at foot... by lawpoop · · Score: 5, Insightful

    You've got to be kidding, right? You actually think MS should just not develop products because there are a bunch of various different open source tools people could use instead? That makes absolutely no sense whatsoever. You're right, it makes no sense whatsoever, because you completely missed the point.

    He's saying that MS should not try to squash community efforts to create great software on Windows platforms. You might need to read that again for it to sink in. He's not saying stop writing software altogether. He's not saying discontinue SQL server because there's some shareware database out there.

    What he is saying is that they don't need to control every successful application on the Windows platform. If they try to, they will both a) breed bad will amongst the developer community, which will hinder Windows application development, which will cause great development to happen in other platforms, and b) waste a lot of money and time in development and support trying to fill every software niche that exists in a platform. They can't write *all* the software for Windows.

    Simply put, MS alone cannot provide as great a Windows experience as MS + developer community can. But every time some great developer makes a wonderful product for Windows, they either squash it or snatch it up and abandon it. At every opportunity they destroy the Windows development community. Not only do they want you to run only Windows, the want you running only MS software on it. And they just won't be able to provide all the software that a user will want on their system. It's the old Soviet model of central planning, where Moscow decided the details of the economy from Khazakstan to Siberia. Eventually it implodes under its own weight.
    --
    Computers are useless. They can only give you answers.
    -- Pablo Picasso