File: TransientDependencyResolverTests.cs

package info (click to toggle)
mono 3.2.8%2Bdfsg-10
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 527,964 kB
  • ctags: 623,327
  • sloc: cs: 3,938,236; xml: 1,891,753; ansic: 418,737; java: 59,920; sh: 15,754; makefile: 11,067; sql: 7,956; perl: 2,279; cpp: 1,380; yacc: 1,203; python: 594; asm: 422; sed: 16; php: 1
file content (85 lines) | stat: -rw-r--r-- 3,554 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
// Copyright (c) Microsoft Open Technologies, Inc. All rights reserved. See License.txt in the project root for license information.

namespace System.Data.Entity.Config
{
    using System.Collections.Concurrent;
    using System.Linq;
    using Xunit;

    public class TransientDependencyResolverTests : TestBase
    {
        [Fact]
        public void Constructors_throw_for_null_instance()
        {
            Assert.Equal(
                "activator",
                Assert.Throws<ArgumentNullException>(() => new TransientDependencyResolver<object>(null)).ParamName);

            Assert.Equal(
                "activator",
                Assert.Throws<ArgumentNullException>(() => new TransientDependencyResolver<object>(null, "Karl")).ParamName);
        }

        public interface IPilkington
        {
        }

        public class Karl : IPilkington
        {
        }

        public interface IGervais
        {
        }

        [Fact]
        public void GetService_returns_unnamed_instance_of_contract_interface()
        {
            Assert.NotNull(new TransientDependencyResolver<IPilkington>(() => new Karl()).GetService<IPilkington>());
        }

        [Fact]
        public void GetService_returns_named_instance_of_contract_interface()
        {
            Assert.NotNull(new TransientDependencyResolver<IPilkington>(() => new Karl(), "Karl").GetService<IPilkington>("Karl"));
        }

        [Fact]
        public void GetService_returns_null_when_contract_interface_does_not_match()
        {
            Assert.Null(new TransientDependencyResolver<IPilkington>(() => new Karl()).GetService<IGervais>());
            Assert.Null(new TransientDependencyResolver<IPilkington>(() => new Karl(), null).GetService<IGervais>());
            Assert.Null(new TransientDependencyResolver<IPilkington>(() => new Karl(), "Karl").GetService<IGervais>("Karl"));
        }

        [Fact]
        public void GetService_returns_null_when_name_does_not_match()
        {
            Assert.Null(new TransientDependencyResolver<IPilkington>(() => new Karl(), "Karl").GetService<IPilkington>("Ricky"));
            Assert.Null(new TransientDependencyResolver<IPilkington>(() => new Karl(), "Karl").GetService<IPilkington>());
            Assert.Null(new TransientDependencyResolver<IPilkington>(() => new Karl(), "Karl").GetService<IGervais>("Ricky"));
        }

        /// <summary>
        ///     This test makes calls from multiple threads such that we have at least some chance of finding threading
        ///     issues. As with any test of this type just because the test passes does not mean that the code is
        ///     correct. On the other hand if this test ever fails (EVEN ONCE) then we know there is a problem to
        ///     be investigated. DON'T just re-run and think things are okay if the test then passes.
        /// </summary>
        [Fact]
        public void GetService_can_be_accessed_from_multiple_threads_concurrently()
        {
            for (var i = 0; i < 30; i++)
            {
                var bag = new ConcurrentBag<IPilkington>();
                var karl = new Karl();
                var resolver = new TransientDependencyResolver<IPilkington>(() => karl, "Karl");

                ExecuteInParallel(() => bag.Add(resolver.GetService<IPilkington>("Karl")));

                Assert.Equal(20, bag.Count);
                Assert.True(bag.All(c => karl == c));
            }
        }
    }
}