Esempio n. 1
0
        /// <summary>
        /// Throws the specified exception when the currently configured
        /// call gets called.
        /// </summary>
        /// <param name="configuration">The configuration to use.</param>
        /// <param name="exceptionFactory">A function that returns the exception to throw when invoked.</param>
        /// <typeparam name="TInterface">The type of configuration interface to return.</typeparam>
        /// <returns>Configuration object.</returns>
        public static IAfterCallConfiguredConfiguration <TInterface> Throws <TInterface>(this IExceptionThrowerConfiguration <TInterface> configuration, Func <Exception> exceptionFactory)
        {
            Guard.AgainstNull(configuration, nameof(configuration));
            Guard.AgainstNull(exceptionFactory, nameof(exceptionFactory));

            return(configuration.Throws(_ => exceptionFactory()));
        }
Esempio n. 2
0
        /// <summary>
        /// Throws the specified exception when the currently configured
        /// call gets called.
        /// </summary>
        /// <param name="configuration">The configuration to use.</param>
        /// <param name="exceptionFactory">A function that returns the exception to throw when invoked.</param>
        /// <typeparam name="T1">Type of the first argument of the faked method call</typeparam>
        /// <typeparam name="T2">Type of the second argument of the faked method call</typeparam>
        /// <typeparam name="T3">Type of the third argument of the faked method call</typeparam>
        /// <typeparam name="T4">Type of the fourth argument of the faked method call</typeparam>
        /// <returns>Configuration object.</returns>
        /// <exception cref="FakeConfigurationException"> when the signatures of the faked method and the <paramref name="exceptionFactory"/> do not match</exception>
        public static IAfterCallSpecifiedConfiguration Throws <T1, T2, T3, T4>(this IExceptionThrowerConfiguration configuration, Func <T1, T2, T3, T4, Exception> exceptionFactory)
        {
            return(configuration.Throws(call =>
            {
                AssertThatSignaturesAreEqual(call.Method, exceptionFactory.Method, NameOfThrowsFeature);

                return exceptionFactory(call.GetArgument <T1>(0), call.GetArgument <T2>(1), call.GetArgument <T3>(2), call.GetArgument <T4>(3));
            }));
        }
Esempio n. 3
0
        /// <summary>
        /// Throws the specified exception when the currently configured
        /// call gets called.
        /// </summary>
        /// <param name="configuration">The configuration to use.</param>
        /// <param name="exceptionFactory">A function that returns the exception to throw when invoked.</param>
        /// <typeparam name="TInterface">The type of configuration interface to return.</typeparam>
        /// <typeparam name="T1">Type of the first argument of the faked method call.</typeparam>
        /// <typeparam name="T2">Type of the second argument of the faked method call.</typeparam>
        /// <returns>Configuration object.</returns>
        /// <exception cref="FakeConfigurationException">The signatures of the faked method and the <paramref name="exceptionFactory"/> do not match.</exception>
        internal static IAfterCallConfiguredConfiguration <TInterface> Throws <TInterface, T1, T2>(this IExceptionThrowerConfiguration <TInterface> configuration, Func <T1, T2, Exception> exceptionFactory)
        {
            Guard.AgainstNull(configuration, nameof(configuration));

            return(configuration.Throws(call =>
            {
                ValueProducerSignatureHelper.AssertThatValueProducerSignatureSatisfiesCallSignature(call.Method, exceptionFactory.GetMethodInfo(), NameOfThrowsFeature);

                return exceptionFactory(call.GetArgument <T1>(0), call.GetArgument <T2>(1));
            }));
        }
        /// <summary>
        /// Throws the specified exception when the currently configured
        /// call gets called.
        /// </summary>
        /// <param name="configuration">The configuration to use.</param>
        /// <param name="exceptionFactory">A function that returns the exception to throw when invoked.</param>
        /// <typeparam name="T1">Type of the first argument of the faked method call.</typeparam>
        /// <typeparam name="T2">Type of the second argument of the faked method call.</typeparam>
        /// <typeparam name="T3">Type of the third argument of the faked method call.</typeparam>
        /// <returns>Configuration object.</returns>
        /// <exception cref="FakeConfigurationException">The signatures of the faked method and the <paramref name="exceptionFactory"/> do not match.</exception>
        public static IAfterCallSpecifiedConfiguration Throws <T1, T2, T3>(this IExceptionThrowerConfiguration configuration, Func <T1, T2, T3, Exception> exceptionFactory)
        {
            Guard.AgainstNull(configuration, "configuration");

            return(configuration.Throws(call =>
            {
                ValueProducerSignatureHelper.AssertThatValueProducerSignatureSatisfiesCallSignature(call.Method, exceptionFactory.Method, NameOfThrowsFeature);

                return exceptionFactory(call.GetArgument <T1>(0), call.GetArgument <T2>(1), call.GetArgument <T3>(2));
            }));
        }
Esempio n. 5
0
        /// <summary>
        /// Throws the specified exception when the currently configured
        /// call gets called.
        /// </summary>
        /// <param name="configuration">The configuration to use.</param>
        /// <param name="exceptionFactory">A function that returns the exception to throw when invoked.</param>
        /// <typeparam name="T1">Type of the first argument of the faked method call.</typeparam>
        /// <returns>Configuration object.</returns>
        /// <exception cref="FakeConfigurationException">The signatures of the faked method and the <paramref name="exceptionFactory"/> do not match.</exception>
        public static IAfterCallSpecifiedConfiguration Throws <T1>(this IExceptionThrowerConfiguration configuration, Func <T1, Exception> exceptionFactory)
        {
            Guard.AgainstNull(configuration, "configuration");

            return(configuration.Throws(call =>
            {
                AssertThatSignaturesAreEqual(call.Method, exceptionFactory.Method, NameOfThrowsFeature);

                return exceptionFactory(call.GetArgument <T1>(0));
            }));
        }
Esempio n. 6
0
        /// <summary>
        /// Throws the specified exception when the currently configured
        /// call gets called.
        /// </summary>
        /// <param name="configuration">The configuration to use.</param>
        /// <param name="exception">The exception to throw when a call that matches is invoked.</param>
        /// <typeparam name="TInterface">The type of configuration interface to return.</typeparam>
        /// <returns>Configuration object.</returns>
        public static IAfterCallConfiguredConfiguration <TInterface> Throws <TInterface>(this IExceptionThrowerConfiguration <TInterface> configuration, Exception exception)
        {
            Guard.AgainstNull(configuration, nameof(configuration));

            return(configuration.Throws(_ => exception));
        }
Esempio n. 7
0
        internal static IAfterCallConfiguredConfiguration <TInterface> Throws <TInterface, T>(this IExceptionThrowerConfiguration <TInterface> configuration) where T : Exception, new()
        {
            Guard.AgainstNull(configuration, nameof(configuration));

            return(configuration.Throws(_ => new T()));
        }
        /// <summary>
        /// Throws the specified exception when the currently configured
        /// call gets called.
        /// </summary>
        /// <param name="configuration">The configuration to use.</param>
        /// <param name="exceptionFactory">A function that returns the exception to throw when invoked.</param>
        /// <returns>Configuration object.</returns>
        public static IAfterCallSpecifiedConfiguration Throws(this IExceptionThrowerConfiguration configuration, Func <Exception> exceptionFactory)
        {
            Guard.AgainstNull(configuration, "configuration");

            return(configuration.Throws(_ => exceptionFactory()));
        }
        /// <summary>
        /// Throws the specified exception when the currently configured
        /// call gets called.
        /// </summary>
        /// <param name="configuration">The configuration to use.</param>
        /// <param name="exception">The exception to throw when a call that matches is invoked.</param>
        /// <returns>Configuration object.</returns>
        public static IAfterCallSpecifiedConfiguration Throws(this IExceptionThrowerConfiguration configuration, Exception exception)
        {
            Guard.AgainstNull(configuration, "configuration");

            return(configuration.Throws(_ => exception));
        }
        public static IAfterCallSpecifiedConfiguration Throws <T>(this IExceptionThrowerConfiguration configuration) where T : Exception, new()
        {
            Guard.AgainstNull(configuration, "configuration");

            return(configuration.Throws(_ => new T()));
        }
Esempio n. 11
0
 /// <summary>
 /// Throws the specified exception when the currently configured
 /// call gets called.
 /// </summary>
 /// <param name="configuration">The configuration to use.</param>
 /// <typeparam name="T">The type of exception to throw.</typeparam>
 /// <returns>Configuration object.</returns>
 public static IAfterCallSpecifiedConfiguration Throws <T>(this IExceptionThrowerConfiguration configuration) where T : Exception, new()
 {
     return(configuration.Throws(_ => new T()));
 }
Esempio n. 12
0
 /// <summary>
 /// Throws the specified exception when the currently configured
 /// call gets called.
 /// </summary>
 /// <param name="configuration">The configuration to use.</param>
 /// <param name="exceptionFactory">A function that returns the exception to throw when invoked.</param>
 /// <returns>Configuration object.</returns>
 public static IAfterCallSpecifiedConfiguration Throws(this IExceptionThrowerConfiguration configuration, Func <Exception> exceptionFactory)
 {
     return(configuration.Throws(_ => exceptionFactory()));
 }
Esempio n. 13
0
 /// <summary>
 /// Throws the specified exception when the currently configured
 /// call gets called.
 /// </summary>
 /// <param name="configuration">The configuration to use.</param>
 /// <param name="exception">The exception to throw when a call that matches is invoked.</param>
 /// <returns>Configuration object.</returns>
 public static IAfterCallSpecifiedConfiguration Throws(this IExceptionThrowerConfiguration configuration, Exception exception)
 {
     return(configuration.Throws(_ => exception));
 }