FoundationStandard.ObjectHydrator
2.0.0
See the version list below for details.
dotnet add package FoundationStandard.ObjectHydrator --version 2.0.0
NuGet\Install-Package FoundationStandard.ObjectHydrator -Version 2.0.0
<PackageReference Include="FoundationStandard.ObjectHydrator" Version="2.0.0" />
paket add FoundationStandard.ObjectHydrator --version 2.0.0
#r "nuget: FoundationStandard.ObjectHydrator, 2.0.0"
// Install FoundationStandard.ObjectHydrator as a Cake Addin #addin nuget:?package=FoundationStandard.ObjectHydrator&version=2.0.0 // Install FoundationStandard.ObjectHydrator as a Cake Tool #tool nuget:?package=FoundationStandard.ObjectHydrator&version=2.0.0
ObjectHydrator
This project allows you to pass custom POCO's to it, and have it return an instance of the class populated with randomly generated but real-world looking data. This random data can be overridden by convention.
Basic syntax looks like this:
Hydrator<Customer> _customerHydrator = new Hydrator<Customer>();
Customer customer = _customerHydrator.GetSingle();
List<Customer> customerlist=_customerHydrator.GetList(20);
Advanced syntax looks like:
Hydrator<Customer> _customerHydrator = new Hydrator<Customer>()
.WithInteger(x => x.CustomerAge, 1, 100)
.WithAmericanPhone(x=>x.CustomerPhone);
A custom generator looks like:
public class FullNameGenerator : IGenerator<string>
{
static readonly IGenerator<string> FirstNameGen = new FirstNameGenerator();
static readonly IGenerator<string> LastNameGen = new LastNameGenerator();
public string Generate()
{
return FirstNameGen.Generate() + " " + LastNameGen.Generate();
}
}
Use a custom generator like this:
Hydrator<Customer> _customerHydrator = new Hydrator<Customer>()
.With(x => x.FullName, new FullNameGenerator());
Changes
Version 2.0
- New Project Name - Reflects that the project is now built as a .netstandard 2.0 library
- Regarding consuming this from a .Net Framework project. Please read this post from Scott Hanselman: https://www.hanselman.com/blog/ReferencingNETStandardAssembliesFromBothNETCoreAndNETFramework.aspx
Version 1.3.0
- Added 3 new generators UnitedKingdomPhoneNumberGenerator, UnitedKingdomInsuranceNumberGenerator, and CulturesGenerator thanks to rikrak and ushenkodmitry
- "Do" method to allow a property to be set from the generated values in other properties, thanks to rikrak
- Fixed randomization method which was excluding the last possible, thanks to rikrak and ushenkodmitry
Version 1.1.0
- Added the ability to respect the StringLength property attribute from System.ComponentModel.DataAnnotations (more annotations are welcome and likely)
Version 1.0.0
- Added the ability to inject Generators at instantiation time. Which looks like this:
var hydrator = new Hydrator<Address>().WithCustomGenerator(x=>x.State, new InjectedGenerator());
Version 0.7.0
- Added new generators: UnitedKingdomCityGenerator, UnitedKingdomCountyGenerator, UnitedKingdomPostcodeGenerator, AlphaNumericGenerator.
Nuget
Coming soon.
Summary
So basically, you create a class and invoke the Hydrator object with that class type. Then call the GetSingle
or GetList
functions and you are returned an instance of the object populated with realistic data. The idea behind it is to use it to replace a database call to use in your UI.
Generators
Presently the generators are pretty simple and can generate limited values, they include:
Generator | Description | Notes |
---|---|---|
FirstName | Returns a random english First Name | |
LastName | Return a random english Last Name | |
DateTimeGenerator | Returns a random Date within a given range. | |
AmericanPhone | Returns a randon American Phone Number | |
AmericanAddress | Returns a random American Address (street part) | |
AmericanCity | Returns a random American City | |
AmericanPostalCode | Returns a random Postal Code (including optional +4 component) | |
Integer Generator | Returns an int within a range | |
Enum Generator | Define the enum and it will return the string value of a random one | |
Boolean Generator | Returns a random boolean | |
AmericanState | Returns a random US abbreviation | |
EmailAddress | Returns a random email address | Thanks ScottMonnig! |
Business Name Generator | Returns a random 3 part business name | |
URL Generator | Returns random URL based on BusinessName Generator | |
IPAddress Generator | Returns a random ip address | |
TextGenerator | Random Greek Text | |
CountryCode | Random Country Code | |
ByteArray Generator | Returns an array of random bytes | |
GUID Generator | Returns a new GUID | |
TypeGenerator | Return a hydrated object of Type | |
TypeListGenerator | Return a list of objects | |
PasswordGenerator | Returns a string of random pw characters with length parameter | |
UnitedKingdomCityGenerator | Returns a UK City | Thanks to fuzzy-afterlife |
UnitedKingdomCountyGenerator | Returns a UK County | Thanks to fuzzy-afterlife |
UnitedKingdomPostcodeGenerator | Returns a UK Post Code | Thanks to fuzzy-afterlife |
UnitedKingdomPhoneNumberGenerator | Returns a UK Phone | Thanks to rikrak |
UnitedKingdomInsuranceNumberGenerator | Returns a UK Ins Number | Thanks to rikrak |
AlphaNumericGenerator | Returns an string with alpha chars of n length | Thanks to fuzzy-afterlife |
CulturesGenerator | Returns a Culture Info property | Thanks to ushenkodmitry |
All values can be overridden so you can do things like fake search results etc...
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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 was computed. 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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- System.ComponentModel.Annotations (>= 4.5.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
First .netstandard version