Mirage 4.0.96

There is a newer version of this package available.
See the version list below for details.
dotnet add package Mirage --version 4.0.96                
NuGet\Install-Package Mirage -Version 4.0.96                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Mirage" Version="4.0.96" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Mirage --version 4.0.96                
#r "nuget: Mirage, 4.0.96"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Mirage as a Cake Addin
#addin nuget:?package=Mirage&version=4.0.96

// Install Mirage as a Cake Tool
#tool nuget:?package=Mirage&version=4.0.96                

Mirage

.NET Publish

Mirage is an open source library for .Net designed to create random data for POCOs, unit tests, etc. Supports .Net Core as well as full .Net.

Setting Up the Library

Mirage relies on Canister in order to hook itself up. In order for this to work, you must do the following at startup:

var MyServices = new ServiceCollection();
...
MyServices.AddCanisterModules();  // Should be last call in order to find any services that you might have added manually.
                                  // Any services added after this may not be found by the system.
				

When this is done, Mirage is ready to use.

Basic Usage

The main class of interest is the Random class:

Mirage.Random RandomObj = new Mirage.Random();

This class has a number of helper functions including a generic Next function:

RandomObj.Next<short>();
RandomObj.Next<float>();
RandomObj.Next<TimeSpan>();

You can also Specify a number of items that you want returned:

var MyList = RandomObj.Next<short>(4);

The MyList object would contain four shorts. You can similarly pull a random item from a list:

var Item = RandomObj.Next(MyList);

This would return a random short from the MyList object specified above. Or you can simply shuffle a list into a random order:

MyList = RandomObj.Shuffle(MyList);

There is also a thread safe version of Next that is available:

var RandomValue=RandomObj.ThreadSafeNext();

Lastly you can randomly generate an entire class as needed:

public class RandomTestClass
{
    [IntGenerator(-100, 100)]
    public int A { get; set; }

    [LoremIpsum]
    public string B { get; set; }

    [FloatGenerator(0, 1)]
    public float C { get; set; }

    [IntGenerator(1, 100)]
    public int D { get; set; }
}

...

var Rand = new Mirage.Random();
var Class = Rand.Next<RandomTestClass>();

This will create an object of the type specified and randomly assign values to the properties based on the attributes placed on them. The system has one for all of the basic types as well as a number of string generators including:

  1. Company
  2. Full Address
  3. City
  4. Domain name
  5. Email address
  6. Phone number
  7. State abbreviation
  8. State
  9. Zip Code
  10. Street Address
  11. Female/male first name
  12. Last name
  13. Female/Male name
  14. Female/male prefix
  15. Name suffix
  16. Full name generator that is male/female/either
  17. Lorem Ipsum
  18. Pattern based
  19. Regex based
  20. "Problem" strings

Adding Your Own Generator

You may wish to create your own random generator or replace one that is already in the system. In order to do this simply create a class that implements the IGenerator class. Simply specify in the class what type it generates and the system will either add it to the list of generators or replace the existing one with your own. As long as you either don't specify which modules to load or include your target assembly when calling AddCanisterModules, the system will then pick it up automatically and call it as requested. Similarly if you wish for it to be picked up when generating a class, make sure your class inherits from GeneratorAttributeBase. If it does, the random class generation will pick it up.

Installation

The library is available via Nuget with the package name "Mirage". To install it run the following command in the Package Manager Console:

Install-Package Mirage

Build Process

In order to build the library you will require the following:

  1. Visual Studio 2017

Other than that, just clone the project and you should be able to load the solution and build without too much effort.

Other Info

The problem strings generator is based off of the Max Woolf's "Big List of Naughty Strings" which is MIT licensed.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (4)

Showing the top 4 NuGet packages that depend on Mirage:

Package Downloads
Inflatable

Inflatable is a simple ORM.

Mecha.Core

Mecha is a C# library that enables automatic testing of classes with the goal of finding ways to break the code. It provides various testing capabilities such as unit testing, security testing through data fuzzing, checking for concurrency issues, and verifying fault tolerance. With just a single line of code, Mecha can automatically test every method in a class. The library seamlessly integrates with your existing testing framework.

TestFountain

TestFountain is a set of addons/extensions for xUnit.net to help with things like data generation.

sundial.core

Sundial is a profiler library used for both comparison of multiple bits of code and hot spot detection.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
5.0.2 20 1/9/2025
5.0.1 410 12/10/2024
5.0.0 1,806 11/24/2024
4.1.13 5,313 9/24/2024
4.1.12 2,137 8/29/2024
4.1.11 398 8/26/2024
4.1.10 305 8/24/2024
4.1.9 792 8/21/2024
4.1.8 711 8/19/2024
4.1.7 660 8/14/2024
4.1.6 778 8/3/2024
4.1.5 982 7/24/2024
4.1.4 698 7/10/2024
4.1.3 1,451 6/27/2024
4.1.2 322 6/25/2024
4.1.1 681 6/21/2024
4.1.0 247 6/21/2024
4.0.109 359 6/19/2024
4.0.108 368 6/18/2024
4.0.107 596 6/13/2024
4.0.106 331 6/13/2024
4.0.105 984 5/30/2024
4.0.104 354 5/30/2024
4.0.103 1,308 5/16/2024
4.0.102 306 5/16/2024
4.0.101 775 5/7/2024
4.0.100 367 5/6/2024
4.0.99 680 5/2/2024
4.0.98 290 5/2/2024
4.0.97 108 5/2/2024
4.0.96 447 4/29/2024
4.0.95 1,122 4/12/2024
4.0.94 341 4/11/2024
4.0.93 334 4/10/2024
4.0.92 666 4/2/2024
4.0.91 344 3/29/2024
4.0.90 400 3/28/2024
4.0.89 899 3/18/2024
4.0.88 281 3/15/2024
4.0.87 319 3/14/2024
4.0.86 363 3/13/2024
4.0.85 520 3/11/2024
4.0.84 295 3/8/2024
4.0.83 353 3/7/2024
4.0.82 326 3/6/2024
4.0.81 344 3/5/2024
4.0.80 354 3/4/2024
4.0.79 851 2/29/2024
4.0.78 311 2/28/2024
4.0.77 297 2/27/2024
4.0.76 438 2/26/2024
4.0.75 146 2/23/2024
4.0.74 232 2/22/2024
4.0.73 156 2/22/2024
4.0.72 153 2/21/2024
4.0.71 156 2/21/2024
4.0.70 239 2/16/2024
4.0.69 321 2/14/2024
4.0.68 235 2/12/2024
4.0.67 185 2/9/2024
4.0.66 174 2/9/2024
4.0.65 206 2/7/2024
4.0.64 175 2/6/2024
4.0.63 2,081 2/5/2024
4.0.62 677 2/1/2024
4.0.61 154 1/31/2024
4.0.60 1,770 1/24/2024
4.0.59 253 1/24/2024
4.0.58 338 1/22/2024
4.0.57 850 1/11/2024
4.0.56 338 1/11/2024
4.0.55 1,303 12/27/2023
4.0.54 877 12/19/2023
4.0.53 636 12/14/2023
4.0.52 322 12/13/2023
4.0.51 256 12/12/2023
4.0.50 1,526 11/23/2023
4.0.49 390 11/21/2023
4.0.48 252 11/20/2023
4.0.47 290 11/17/2023
4.0.46 661 11/16/2023
4.0.45 305 11/15/2023
4.0.44 652 11/8/2023
4.0.43 275 11/7/2023
4.0.42 264 11/6/2023
4.0.41 322 11/4/2023
4.0.40 623 10/31/2023
4.0.39 292 10/30/2023
4.0.38 341 10/27/2023
4.0.37 303 10/26/2023
4.0.36 337 10/25/2023
4.0.35 744 10/12/2023
4.0.34 174 10/11/2023
4.0.33 782 9/25/2023
4.0.32 448 9/20/2023
4.0.31 297 9/19/2023
4.0.30 314 9/18/2023
4.0.29 520 9/14/2023
4.0.28 303 9/13/2023
4.0.27 331 9/12/2023
4.0.26 357 9/11/2023
4.0.25 144 9/11/2023
4.0.24 650 9/8/2023
4.0.23 341 9/7/2023
4.0.22 368 9/6/2023
4.0.21 396 9/4/2023
4.0.20 382 9/2/2023
4.0.19 157 9/1/2023
4.0.18 433 8/31/2023
4.0.17 578 8/29/2023
4.0.16 403 8/29/2023
4.0.15 611 8/24/2023
4.0.14 371 8/24/2023
4.0.13 355 8/22/2023
4.0.12 540 8/18/2023
4.0.11 1,970 8/9/2023
4.0.10 365 8/8/2023
4.0.9 229 8/8/2023
4.0.8 458 8/7/2023
4.0.7 260 8/4/2023
4.0.6 442 8/2/2023
4.0.5 380 7/27/2023
4.0.4 314 7/25/2023
4.0.3 425 7/20/2023
4.0.2 536 7/14/2023
4.0.1 793 12/13/2022
4.0.0 2,042 12/12/2022
3.0.19 2,875 6/10/2022
3.0.17 878 2/17/2022
3.0.16 493 2/3/2022
3.0.15 2,443 1/11/2022
3.0.14 2,294 7/22/2021
3.0.13 380 7/22/2021
3.0.11 386 7/20/2021
3.0.10 630 6/16/2021
3.0.9 966 6/16/2021
3.0.8 6,950 1/6/2021
3.0.6 2,934 9/13/2020
3.0.5 7,903 3/25/2020
3.0.4 1,627 3/18/2020
3.0.3 580 3/17/2020
3.0.2 588 3/17/2020
3.0.1 1,597 3/1/2020
3.0.0 3,212 12/23/2019
2.0.12 1,521 3/12/2019
2.0.11 677 3/12/2019
2.0.10 1,388 2/21/2019
2.0.9 3,130 8/14/2018
2.0.8 1,608 8/10/2018
2.0.7 938 8/9/2018
2.0.6 961 8/9/2018
2.0.5 999 8/9/2018
2.0.4 1,026 8/8/2018
2.0.3 1,116 8/8/2018
2.0.2 3,497 6/1/2018
2.0.1 1,881 5/22/2018
2.0.0 4,518 1/2/2018
1.0.10 14,305 6/13/2017
1.0.9 1,729 5/17/2017
1.0.8 1,099 3/22/2017
1.0.7 1,106 2/21/2017
1.0.5 1,141 2/8/2017
1.0.4 1,167 2/7/2017
1.0.3 1,179 2/6/2017
1.0.2 1,114 1/24/2017
1.0.1 1,133 1/18/2017