Jaa


Guidance Automation Extensions and Toolkit: June 2006 Release

The patterns & practices team is please to announce the availability of the June 2006 CTP of the Guidance Automation Extensions (GAX) and Guidance Automation Toolkit (GAT)! As reported previously, this is a relatively minor update to the previous December 2005 CTP which includes some important bug fixes and usability improvements.

What are GAX and GAT anyway?

GAX and GAT are really the foundation of Microsoft's Software Factories initative. Software Factories built on these technologies are collections of guidance that help architects and developers build specific types of applications with improved consistency, quality and productivity. This is achieved by integrating automated guidance related to the factory's application scenario deeply into Visual Studio - for example, using templates, wizards, recipes and code generation, along with supporting patterns and architectural documentation. The patterns & practices team is currently working on several Software Factories, including the Web Service Software Factory, Smart Client Software Factory and Mobile Client Software Factory.

The Guidance Automation Extensions (GAX) extend Visual Studio 2005 to provide the core runtime environment for the guidance packages included in these factories. GAX allows you to install and enable a guidance package for a Visual Studio Solution, and it will add the appropriate templates, recipes and wizards to the development environment to make it easy for you to complete tasks, such as adding a service interface or business entity to your web service solution. The new version of GAX also includes a new window called the Guidance Navigator which makes it easy to discover the available guidance and read any related documentation. You must have GAX installed before you can use any guidance packages.

The Guidance Automation Toolkit (GAT) provides a simple guidance package that lets you author new guidance packages or customize existing guidance packages. This is extremely important, since even though we are working hard to make our Software Factories as relevant as possible, each organization and project is different - so by customizing the guidance packages you can ensure that they fully meet your requirements and comply with your architecture and environment. You do not need GAT installed to use a guidance package, but over time it's likely you'll want to customize something so it's definitely worth installing now.

Should I upgrade from the previous release?

Yes - while this is a relatively minor update from the previous December 2005 CTP, it does contain some important fixes and enhancements as outlined earlier by Wojtek. Even more importantly, the wave of p&p Software Factories that will be hitting the streets over the next few months will require the new release, so upgrading is definitely recommended.

Unfortunately it is currently necessary to uninstall any guidance packages you already have installed (including GAT) before you can uninstall the old GAX. You can then install the new GAX and reinstall any guidance packages you want to use. Believe me we know this is a pain (we've gone through this process a lot in our projeccts) - so it's definitely something we'll work to improve in the future.

Will existing guidance packages still work with the June 2006 release?

In general, yes - but there are a couple of tricks you'll need to know.

First, there are some minor changes in the new version of the T4 text templating engine that we include in this release (it's the same version that's in the June 2006 release of DSL Tools). Depending on how the templates were originally authored, it may be necessary to make minor changes to any included T4 templates so they can run on the new version. In general this just involves adding the declaration <#@ assembly name="System.dll" #> to the top of the file.

The other thing to watch out for is that the version numbers for the GAX and GAT assemblies have changed. We install binding redirects with the new GAX to enable older guidance packages to redirect to the new versions - but this only works at runtime, not when compiling the source with Visual Studio. So if you open the source of an old guidance package with the new GAT/GAX installed, you will need to update your assembly references.

You can get more details on these issues in the Release Notes installed with GAX.

Why is this still a CTP? What's the future of this technology?

Like the previous releases, this new release is still labeled a Community Technology Preview. This is because the deliverables are still unsupported, and we can't promise to maintain compatibility as we continue to evolve the technologies. Keep in mind that both GAX and GAT are only designed to run on development machines, not production servers, so even if something does blow up, it's not going to blow up your production systems. That said, we've gone through the same quality gates with GAT and GAX as we do with any other p&p release, and we are confident we have a high quality release. Since all of our factories will depend on this technology, we need to be!

We really are very excited by the potential of this technology and of Software Factories, and we are continuing to work on enhancing the infrastructure, authoring environment and the factories themselves. While we don't yet have a solid product plan that we can commit to, we are working to significantly enhance these deliverables and integrate them much more deeply into Visual Studio and Team System. The goal is that eventually most of the capabilities you see in GAX and GAT will be absorbed into Visual Studio. We're going to need your help to figure out what areas we should be focusing on, so expect to hear much more about this work on my blog and on the Guidance Automation Toolkit Forum.

This posting is provided "AS IS" with no warranties, and confers no rights.

Comments

  • Anonymous
    June 24, 2006
    The comment has been removed

  • Anonymous
    June 24, 2006
    For the T4 Engine do you know if you can create your own host (e.g. a console app) that can load an xml file and loop through it in order to call the t4 engine multiple times and pass custom objects to it (e.g. class, array of classes, xml etc)?

    Many Thanks,

    John

  • Anonymous
    June 25, 2006
    Following up on my previous post. Check out Tom's&amp;nbsp;new article on this new release.
    Very important...

  • Anonymous
    June 25, 2006
    And probably you know the culprits&amp;nbsp;are the super-cool Guidance Automation Extensions (GAX)&amp;nbsp;and...

  • Anonymous
    June 25, 2006
    Yes, definitely you can.
    Get the DSL toolkit, which comes with full documentation on how to use and extend the T4 engine.

  • Anonymous
    June 26, 2006
    The comment has been removed

  • Anonymous
    June 26, 2006
    I response to John's question on T4. Yes it is possible to do this. I found a link to a really useful document from Microsoft (dv_dslconrd.chm) on a GarethJ's Blog (http://blogs.msdn.com/garethj/archive/2005/12/30/dsldocs.asp).

  • Anonymous
    June 26, 2006
    It must be the end of the fiscal year of something, because we have yet another new release to tell you...

  • Anonymous
    June 26, 2006
    The comment has been removed

  • Anonymous
    June 27, 2006
    &quot;Want to see the Enterprise Library application blocks in action in a realistic service oriented application?...

  • Anonymous
    June 27, 2006
    &quot;Want to see the Enterprise Library application blocks in action in a realistic service oriented application?...

  • Anonymous
    June 27, 2006
    PingBack from https://blogs.msdn.com:443/federaldev/archive/2006/06/27/648619.aspx

  • Anonymous
    June 27, 2006
    HELP! Can't uninstall old version of GAX.
    I get a message you must first uninstall WCFTooling, HoLPackage, guid DD259E37...
    I've uninstalled even the CAB and EntLib Hol and WCF and tried msiZap with no luck.
    Jay AT Accelerateddata.com

  • Anonymous
    June 27, 2006
    The comment has been removed

  • Anonymous
    June 28, 2006
    I am happy to announce the release 1.1 of GAX.

    Read more about this release at: http://blogs.msdn.com/tomholl/archive/2006/06/24/645882.asp...

  • Anonymous
    July 01, 2006
    The July drop of the Web Service Factory or Service BAT is out! I am super excited about this as it is...

  • Anonymous
    September 06, 2006
    Have you ever tried to remove a guidance package and got an error during the uninstallation process,...

  • Anonymous
    September 22, 2006
    The comment has been removed

  • Anonymous
    September 30, 2006
    The comment has been removed

  • Anonymous
    December 24, 2006
    PingBack from http://blog.objectwire.com/2006/12/25/getting-back-to-basicsguidance-automation/

  • Anonymous
    June 13, 2007
    I have had my share of struggle when trying to install Ent. Lib 3.0 and getting Application block Software

  • Anonymous
    August 28, 2007
    The comment has been removed

  • Anonymous
    December 11, 2007
    Both the July drop of the Web Service Factory or Service BAT is out and the June SCBAT are out. I am

  • Anonymous
    July 06, 2008
    Guidance Automation Extensions and Toolkit: June 2006 Release

  • Anonymous
    December 04, 2008
    Both the July drop of the Web Service Factory or Service BAT is out and the June SCBAT are out. I am super excited about this as it is nearing V1 and we are using both of these in production code. I have been blogging about the Service Bat since the begining