예제 #1
0
        /// <summary>
        /// Creates and seeds a new part.
        /// </summary>
        /// <param name="item">The item this part should belong to.</param>
        /// <param name="roleId">The optional part role ID.</param>
        /// <param name="factory">The part seeder factory. This is used
        /// for layer parts, which need to seed a set of fragments.</param>
        /// <returns>A new part.</returns>
        /// <exception cref="ArgumentNullException">item or factory</exception>
        public override IPart GetPart(IItem item, string roleId,
                                      PartSeederFactory factory)
        {
            if (item == null)
            {
                throw new ArgumentNullException(nameof(item));
            }
            if (factory == null)
            {
                throw new ArgumentNullException(nameof(factory));
            }

            CorrExchangesPart part = new CorrExchangesPart();

            SetPartMetadata(part, roleId, item);

            for (int n = 1; n <= Randomizer.Seed.Next(1, 3 + 1); n++)
            {
                part.Exchanges.Add(new Faker <CorrExchange>()
                                   .RuleFor(e => e.IsDubious, f => f.Random.Bool(0.3f))
                                   .RuleFor(e => e.IsIndirect, f => f.Random.Bool())
                                   .RuleFor(e => e.IsFromParticipant, f => f.Random.Bool())
                                   .RuleFor(e => e.Chronotopes,
                                            new List <Chronotope> {
                    SeederHelper.GetChronotope("from", 1200)
                })
                                   .RuleFor(e => e.Participants, SeederHelper.GetDecoratedIds(1, 2))
                                   .RuleFor(e => e.Sources, SeederHelper.GetDocReferences(1, 3))
                                   .RuleFor(e => e.Attachments, SeederHelper.GetAttachments(1, 3))
                                   .Generate());
            }

            return(part);
        }
예제 #2
0
        /// <summary>
        /// Creates and seeds a new part.
        /// </summary>
        /// <param name="item">The item this part should belong to.</param>
        /// <param name="roleId">The optional part role ID.</param>
        /// <param name="factory">The part seeder factory. This is used
        /// for layer parts, which need to seed a set of fragments.</param>
        /// <returns>A new part.</returns>
        /// <exception cref="ArgumentNullException">item or factory</exception>
        public override IPart GetPart(IItem item, string roleId,
                                      PartSeederFactory factory)
        {
            if (item == null)
            {
                throw new ArgumentNullException(nameof(item));
            }
            if (factory == null)
            {
                throw new ArgumentNullException(nameof(factory));
            }

            int birthYear = Randomizer.Seed.Next(1200, 1300);

            PersonPart part = new Faker <PersonPart>()
                              .RuleFor(p => p.PersonId, f => f.Lorem.Word())
                              .RuleFor(p => p.ExternalIds, SeederHelper.GetExternalIds(1, 2))
                              .RuleFor(p => p.Names, new List <PersonName>(new[]
            {
                new Faker <PersonName>()
                .RuleFor(pn => pn.Language, "lat")
                .RuleFor(pn => pn.Parts, f =>
                         new List <PersonNamePart>(new[]
                {
                    new PersonNamePart
                    {
                        Type  = "first",
                        Value = f.Lorem.Word(),
                    },
                    new PersonNamePart
                    {
                        Type  = "last",
                        Value = f.Lorem.Word(),
                    }
                }))
                .Generate()
            }))
                              .RuleFor(p => p.Sex, f => f.PickRandom('M', 'F'))
                              .RuleFor(e => e.Chronotopes, new List <Chronotope>
            {
                SeederHelper.GetChronotope("birth", birthYear),
                SeederHelper.GetChronotope("death", birthYear + 80),
            })
                              .RuleFor(p => p.Bio, f => f.Lorem.Sentence())
                              .Generate();

            SetPartMetadata(part, roleId, item);

            return(part);
        }