Click here to Skip to main content
15,886,137 members
Articles / Programming Languages / Visual Basic

CuttingEdge.Conditions

Rate me:
Please Sign up or sign in to vote.
4.59/5 (19 votes)
23 Jun 2011MIT3 min read 125K   67   84  
A pre- and postcondition validation framework based on .NET 3.5 extension methods
��/* The CuttingEdge.Conditions library enables developers to validate pre- and postconditions in a fluent 

* manner.

* 

* Copyright (C) 2008 S. van Deursen

* 

* To contact me, please visit my blog at http://www.cuttingedge.it/blogs/steven/ 

*

* This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser 

* General Public License as published by the Free Software Foundation; either version 2.1 of the License, or

* (at your option) any later version.

*

* This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the 

* implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public

* License for more details.

*/



using System;

using System.Globalization;

using System.Threading;



using Microsoft.VisualStudio.TestTools.UnitTesting;



namespace CuttingEdge.Conditions.UnitTests.StringTests

{

    /// <summary>

    /// Tests the ValidatorExtensions.StartsWith method.

    /// </summary>

    [TestClass]

    public class StringStartsWithTests

    {

        [TestMethod]

        [Description("Calling StartsWith on string x with 'x StartsWith x' should pass.")]

        public void StartsWithTest01()

        {

            string a = "test";

            a.Requires().StartsWith(a);

        }



        [TestMethod]

        [Description("Calling StartsWith on string x (\"test\") with 'x StartsWith \"tes\"' should pass.")]

        public void StartsWithTest02()

        {

            string a = "test";

            a.Requires().StartsWith("tes");

        }



        [TestMethod]

        [ExpectedException(typeof(ArgumentException))]

        [Description("Calling StartsWith on string x (\"test\") with 'x StartsWith null' should fail.")]

        public void StartsWithTest03()

        {

            string a = "test";

            // A null value will never be found

            a.Requires().StartsWith(null);

        }



        [TestMethod]

        [Description("Calling StartsWith on string x (\"test\") with 'x StartsWith \"\"' should pass.")]

        public void StartsWithTest04()

        {

            string a = "test";

            // An empty string will always be found

            a.Requires().StartsWith(String.Empty);

        }



        [TestMethod]

        [ExpectedException(typeof(ArgumentNullException))]

        [Description("Calling StartsWith on string x (null) with 'x StartsWith \"\"' should fail.")]

        public void StartsWithTest05()

        {

            string a = null;

            // A null string only contains other null strings.

            a.Requires().StartsWith(String.Empty);

        }



        [TestMethod]

        [Description("Calling StartsWith on string x (\"test\") with 'x StartsWith null' should pass.")]

        public void StartsWithTest06()

        {

            string a = null;

            a.Requires().StartsWith(null);

        }



        [TestMethod]

        [ExpectedException(typeof(ArgumentException))]

        [Description("Calling StartsWith on string x (\"test\") with 'x StartsWith \"test me\"' should fail.")]

        public void StartsWithTest07()

        {

            string a = "test";

            a.Requires().StartsWith("test me");

        }



        [TestMethod]

        [Description("Calling StartsWith on string x (\"test\") with 'x StartsWith \"test me\"' should fail with a correct exception message.")]

        public void StartsWithTest08()

        {

            string expectedMessage =

                "a should start with 'test me'." + Environment.NewLine +

                TestHelper.ArgumentExceptionParameterName + ": a";



            try

            {

                string a = "test";

                a.Requires("a").StartsWith("test me");

            }

            catch (Exception ex)

            {

                Assert.AreEqual(expectedMessage, ex.Message);

            }

        }



        [TestMethod]

        [Description("Calling StartsWith with conditionDescription parameter should pass.")]

        public void StartsWithTest09()

        {

            string a = null;

            a.Requires().StartsWith(null, string.Empty);

        }



        [TestMethod]

        [Description("Calling a failing StartsWith should throw an Exception with an exception message that contains the given parameterized condition description argument.")]

        public void StartsWithTest10()

        {

            string a = null;

            try

            {

                // A null string is considered to have a length of 0.

                a.Requires("a").StartsWith("test", "qwe {0} xyz");

                Assert.Fail();

            }

            catch (ArgumentException ex)

            {

                Assert.IsTrue(ex.Message.Contains("qwe a xyz"));

            }

        }



        [TestMethod]

        [Description("Calling StartsWith should be language dependent.")]

        public void StartsWithTest11()

        {

            CultureInfo originalCulture = Thread.CurrentThread.CurrentCulture;



            string a = "hi ya'all";



            try

            {

                Thread.CurrentThread.CurrentCulture = new CultureInfo("tr-TR");



                // We check this using the Turkish-I problem.

                // see: http://msdn.microsoft.com/en-us/library/ms973919.aspx#stringsinnet20_topic5

                string turkishUpperCase = "H0";



                a.Requires().StartsWith(turkishUpperCase, StringComparison.CurrentCultureIgnoreCase);

            }

            finally

            {

                Thread.CurrentThread.CurrentCulture = originalCulture;

            }   

        }

    }

}

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article, along with any associated source code and files, is licensed under The MIT License


Written By
Software Developer (Senior)
Netherlands Netherlands
I'm a freelance developer from the Netherlands, working with .NET technology on a daily basis, and officially diagnosed as a workaholic.

Comments and Discussions