Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nickdodd79/AutoBogus
A C# library complementing the Bogus generator by adding auto creation and population capabilities.
https://github.com/nickdodd79/AutoBogus
Last synced: 2 months ago
JSON representation
A C# library complementing the Bogus generator by adding auto creation and population capabilities.
- Host: GitHub
- URL: https://github.com/nickdodd79/AutoBogus
- Owner: nickdodd79
- License: mit
- Created: 2017-05-18T10:22:52.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2022-11-03T13:55:57.000Z (about 2 years ago)
- Last Synced: 2024-05-28T06:18:27.348Z (8 months ago)
- Language: C#
- Homepage:
- Size: 393 KB
- Stars: 422
- Watchers: 10
- Forks: 49
- Open Issues: 39
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-reference-tools - AutoBogus
README
[![NuGet](https://img.shields.io/nuget/v/AutoBogus?style=for-the-badge)](https://www.nuget.org/packages/AutoBogus/)
[![NuGet](https://img.shields.io/nuget/dt/AutoBogus?style=for-the-badge)](https://www.nuget.org/packages/AutoBogus/)# AutoBogus
A C# library complementing the [Bogus](https://github.com/bchavez/Bogus) generator by adding auto creation and population capabilities.The following packages are available for download from NuGet:
- [AutoBogus](https://www.nuget.org/packages/AutoBogus)
- [AutoBogus.Conventions](https://www.nuget.org/packages/AutoBogus.Conventions)
- [AutoBogus.FakeItEasy](https://www.nuget.org/packages/AutoBogus.FakeItEasy)
- [AutoBogus.Moq](https://www.nuget.org/packages/AutoBogus.Moq)
- [AutoBogus.NSubstitute](https://www.nuget.org/packages/AutoBogus.NSubstitute)## Configuration
There are several levels of configuration available.- `Global` > this is scoped as the default configuration across all generate requests.
- `Faker` > this is scoped as the configuration applied to all generate requests for an `AutoFaker` instance.
- `Generate` > this is scoped as the configuration for a specific generate request.The above levels are hierarchical and in the order listed. Therefore, if a setting is **not** set for a `Generate` configuration, then the `Faker` value is used and then the `Global`.
#### Builder
A configuration is defined via a builder action that invokes the relevant setup method.```c#
// Configure globally
AutoFaker.Configure(builder =>
{
builder
.WithLocale() // Configures the locale to use
.WithRepeatCount() // Configures the number of items in a collection
.WithDataTableRowCount() // Configures the number of data table rows to generate
.WithRecursiveDepth() // Configures how deep nested types should recurse
.WithTreeDepth() // Configures the tree depth of an object graph
.WithBinder() // Configures the binder to use
.WithFakerHub() // Configures a Bogus.Faker instance to be used - instead of a default instance
.WithSkip() // Configures members to be skipped for a type
.WithOverride(); // Configures the generator overrides to use - can be called multiple times
});// Configure a faker
var faker = AutoFaker.Create(builder => ...);// Configure a generate request
faker.Generate(builder => ...);
faker.Generate(builder => ...);AutoFaker.Generate(builder => ...);
AutoFaker.Generate(builder => ...);// Configure an AutoFaker
var personFaker = new AutoFaker()
.Configure(builder => ...)
.RuleFor(fake => fake.Id, fake => fake.Random.Int())
.Generate();
```The `Generate()` methods also include `WithArgs()` so constructor arguments can be defined for the `TFaker` instance.
## Usage
### AutoFaker
The non-generic `AutoFaker` class provides convenience methods to generate type instances.It can be used statically or as a configured instance. The static methods provide a means of quickly generating types on-the-fly and the instance can be reused across multiple generate requests.
#### Static
```c#
AutoFaker.Generate();
AutoFaker.Generate();
```#### Instance
```c#
var faker = AutoFaker.Create();faker.Generate();
faker.Generate();
```### AutoFaker<T>
The `AutoFaker` class is a **Bogus** wrapper that adds auto generation for member values. In turn, it means all the goodness of **Bogus** is automatically available (e.g. rule sets).```c#
var personFaker = new AutoFaker()
.RuleFor(fake => fake.Id, fake => fake.Random.Int())
.RuleSet("empty", rules =>
{
rules.RuleFor(fake => fake.Id, () => 0);
});// Use explicit conversion or call Generate()
var person1 = (Person)personFaker;
var person2 = personFaker.Generate();person1.Dump();
person2.Dump();// An existing instance can also be populated
var person3 = new Person();personFaker.Populate(person3);
person3.Dump();
```When the `AutoFaker` class is inherited, you can either instantiate an instance or use the `AutoFaker` class to auto instantiate and invoke a `Generate()` method.
```c#
public class PersonFaker : AutoFaker
{
public PersonFaker(int id)
{
RuleFor(fake => fake.Id, () => id)
}
}var id = AutoFaker.Generate();
// Create an instance and call Generate()
var personFaker = new PersonFaker(id);
var person1 = personFaker.Generate();person1.Dump();
// Create a Person instance using AutoFaker.Generate()
// If the AutoFaker class needs constructor arguments, they can be passed using WithArgs()
var person2 = AutoFaker.Generate(builder => builder.WithArgs(id));person2.Dump();
```Note that, should a rule set be used to generate a type, then only members **not** defined in the rule set are auto generated. In the examples above, the `Id` member will **not** be generated, but will instead use the `RuleFor` value.
## Binders
A default `IAutoBinder` implementation is included with **AutoBogus**, but it will not generate interfaces or abstract classes. For this, the following packages are available:- [AutoBogus.FakeItEasy](https://www.nuget.org/packages/AutoBogus.FakeItEasy)
- [AutoBogus.Moq](https://www.nuget.org/packages/AutoBogus.Moq)
- [AutoBogus.NSubstitute](https://www.nuget.org/packages/AutoBogus.NSubstitute)## Skipping
The generating of values can be skipped based on either a type or the member path of a type.```c#
() // Define a generic type
AutoFaker.Configure(builder =>
{
// Types
builder
.WithSkip
.WithSkip(typeof(Country)); // Define a type// Type members
builder
.WithSkip(person => person.Name); // Define using an expression for public members
.WithSkip("Age"); // Define using a string for protected, internal, etc. members
.WithSkip(typeof(Person), "Gender"); // Define using a string for protected, internal, etc. members
});
```## Overrides
In some cases, custom rules are needed to generate a type and for this, **AutoBogus** provides generator overrides. By implementating a class that inherits `AutoGeneratorOverride` and registering it via a configuration, these custom rules can be invoked as part of a generate request.```c#
public class PersonOverride : AutoGeneratorOverride
{
public override bool CanOverride(AutoGenerateContext context)
{
return context.GenerateType == typeof(Person);
}public override void Generate(AutoGenerateOverrideContext context)
{
// Apply an email value to the person
var person = context.Instance as Person;
person.Email = context.Faker.Internet.Email();
}
}// Register the override
AutoFaker.Configure(builder => builder.WithOverride(new PersonOverride()));
```Note that a virtual `Preinitialize` property is available to control whether an initial value should be generated. This defaults to true.
## Behaviors
The following underlying behaviors are in place in **AutoBogus**:- Interface and abstract class types are not auto generated - they will result in `null` values. A custom binder would be needed, like one of the packages listed above.
- Rescursive types - a nested member with the same parent type - will be generated to **2** levels by default to avoid a `StackOverflowException` - `Person.Parent -> Person.Parent -> null`
- Read only properties - if a property is read only but can be resolved as an `ICollection<>` or `IDictionary<,>`, then it will be populated via the `Add()` method.## Conventions
The [AutoBogus.Conventions](https://www.nuget.org/packages/AutoBogus.Conventions) package provides conventions for generating values, currently based on generation type and name. As an example, a property named `Email` and of type `string` will be assigned a value using the `Faker.Internet.Email()` generator.To include the conventions in your project, apply the following configuration at the required level:
```c#
AutoFaker.Configure(builder =>
{
builder.WithConventions();
});
```Each convention generator maps to a **Bogus** generator method and can be configured individually.
```c#
AutoFaker.Configure(builder =>
{
builder.WithConventions(config =>
{
config.FirstName.Enabled = false; // Disables the FirstName generator
config.LastName.AlwaysGenerate = true; // Overrides any LastName values previously generated
config.Email.Aliases("AnotherEmail"); // Generates an email value for members named AnotherEmail
});
});
```## Templating
The [AutoBogus.Templating](https://www.nuget.org/packages/AutoBogus.Templating) package allows value generation rules to be defined using a text based templating notation.This can be used by using the `GenerateWithTemplate()` extension method.
```c#
public class Person
{
public int Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public string Status { get; set; } // Will be auto generated by the underlying AutoBogus generator
}var persons = new AutoFaker().GenerateWithTemplate(@"
Id | FirstName | LastName
0 | John | Smith
1 | Jane | Jones
2 | Bob | Clark
");
```## Contributors
Made with [contributors-img](https://contrib.rocks).