PlayNicely.Projects 1.0.4-prerelease-20240226-104112

This is a prerelease version of PlayNicely.Projects.
There is a newer version of this package available.
See the version list below for details.
dotnet add package PlayNicely.Projects --version 1.0.4-prerelease-20240226-104112                
NuGet\Install-Package PlayNicely.Projects -Version 1.0.4-prerelease-20240226-104112                
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="PlayNicely.Projects" Version="1.0.4-prerelease-20240226-104112">
  <PrivateAssets>all</PrivateAssets>
  <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets>
</PackageReference>                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add PlayNicely.Projects --version 1.0.4-prerelease-20240226-104112                
#r "nuget: PlayNicely.Projects, 1.0.4-prerelease-20240226-104112"                
#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 PlayNicely.Projects as a Cake Addin
#addin nuget:?package=PlayNicely.Projects&version=1.0.4-prerelease-20240226-104112&prerelease

// Install PlayNicely.Projects as a Cake Tool
#tool nuget:?package=PlayNicely.Projects&version=1.0.4-prerelease-20240226-104112&prerelease                

Play Nicely Case Packer

The Play Nicely Case Packer project supports the definition and packaging (for reading or writing) of MSBuild Projects for use in release test cases. While this NuGet package can be used independently its development is a result of the Play Nicely MSBuild tools packages, e.g. NpmNpx or Sass.

Getting Started

This base package supports the definition of a TestCaseProject via a generic FileSystem interface. This interface allows for the definition of directories and files, and also the contents of those files.

The other artefacts support reading or writing of a TestCaseProject to media. At time of writing, the project supports reading from .NET assembly resources and writing to the physical file system. Implement concrete versions of IProjectPackageReader and IProjectPackageWriter if you have a specific media that you wish to support.

Defining Projects

The TestCaseProject class represents a virtual project, you can create a FileSystem by adding directories and files via the FileSystem object using it's fluent interface. You can also specify the ProjectFile from the same file system. Once defined the TestCaseProject doesn't do much on its own, but it is used by the PlayNicely.Executor package to run test cases.

var testCaseProject = new TestCaseProject("my-project");
var projectFile = testCaseProject.AddDirectory("project1")
                                 .AddFile("proj.csproj");

testCaseProject.ProjectFile = projectFile;

using(var writer = new StreamWriter(projectFile.OpenWriteStream()))
{
    writer.WriteLine("<Project Sdk=\"Microsoft.NET.Sdk\">");
    writer.WriteLine("  <PropertyGroup>");
    writer.WriteLine("    <TargetFramework>netstandard2.0</TargetFramework>");
    writer.WriteLine("  </PropertyGroup>");
    writer.WriteLine("</Project>");
}

Using Resource (resx) files

Building test case projects in code is fine, but there is already a tool to easily define and edit MSBuild projects, the IDE. To support this, Case Packer provides a IProjectPackageReader implementation for .NET resources. The basic idea is to add file resources to the resx file with names equivalent to the project file structure. The ResourceSetPackageReader can then be used to read a package into a test case project, including the file contents.

Example

If you have the following project structure...

solution-dir
|-- my-project.Specs           # BDD Specifications for your project
|   |-- TestCases.Projects     # Define your test case 'packages' in resx files
|       |-- Project1.resx
|-- TestCase.Projects          # Define your test case projects in here using familiar tools.
|   |-- Project1
|       |-- Project1.csproj
|       |-- Program.cs
|-- my-solution.sln

The .resx file should have the following resources defined

<?xml version="1.0" encoding="utf-8"?>
<root>
  <data name="Project1/Project1.csproj" type="System.Resources.ResXFileRef, System.Windows.Forms">
    <value>Project1/Project1.csproj;System.String, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089;utf-8</value>
  </data>
  <data name="Project1/Program.cs" type="System.Resources.ResXFileRef, System.Windows.Forms">
    <value>Project1/Program.cs;System.String, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089;utf-8</value>
  </data>
</root>

And then to load these resources into a TestCaseProject you can...

internal static class TestCases
{
    // Where projectName is the same as the resx file name without the extension
    public static async Task<TestCaseProject> LoadAsync(string projectName, CancellationToken cancel)
    {
        ArgumentException.ThrowIfNullOrEmpty(projectName);
        cancel.ThrowIfCancellationRequested();

        var resourceManager = new ResourceManager($"{ResourceNamespace}.{projectName}", ResourceAssembly);

        using var resourceSet = resourceManager.GetResourceSet(CultureInfo.InvariantCulture, true, true)
            ?? throw new TestCaseException(string.Format(ContentRes.Error_ProjectNameDoesNotExist, projectName));
        using var reader = new ResourceSetBlobReader(resourceSet);

        var result = new TestCaseProject(projectName);

        await result.LoadFromAsync(reader, cancel);
        cancel.ThrowIfCancellationRequested();

        return result;
    }

    public static Assembly ResourceAssembly => _resourceAssembly.Value;
    public static string ResourceNamespace => _resourceNamespace.Value;

    private static readonly Lazy<Assembly> _resourceAssembly = new(() => typeof(TestCases).Assembly);
    private static readonly Lazy<string> _resourceNamespace = new(() => typeof(TestCases).Namespace ?? string.Empty);
}
There are no supported framework assets in this package.

Learn more about Target Frameworks and .NET Standard.

  • net8.0

    • No dependencies.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on PlayNicely.Projects:

Package Downloads
PlayNicely.Executor

A framework that facilitates testing of Play Nicely functionality. Provides capability to execute programs, in a controlled environment, against test case projects.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.1.3-beta-550 100 10/4/2024
1.1.3-beta-543 114 9/28/2024
1.1.3-beta-535 108 9/28/2024
1.1.3-beta-529 97 9/23/2024
1.1.3-beta-518 113 9/21/2024
1.1.3-beta-511 99 9/20/2024
1.1.3-beta-509 100 9/20/2024
1.1.3-beta-507 100 9/20/2024
1.1.3-beta-505 99 9/19/2024
1.1.3-beta-501 127 9/18/2024
1.1.3-beta-499 109 9/18/2024
1.1.3-beta-496 114 9/18/2024
1.1.2 168 9/17/2024
1.1.2-beta-494 107 9/18/2024
1.1.2-beta-492 117 9/18/2024
1.1.2-beta-487 113 9/17/2024
1.1.1 222 6/1/2024
1.1.1-beta-479 122 9/14/2024
1.1.1-beta-472 116 9/14/2024
1.1.1-beta-465 131 9/7/2024
1.1.1-beta-450 107 7/14/2024
1.1.1-beta-442 104 7/12/2024
1.1.1-beta-432 107 7/11/2024
1.1.1-beta-418 106 6/1/2024
1.1.1-beta-398 112 6/1/2024
1.1.0 126 5/6/2024
1.1.0-beta-393 122 5/31/2024
1.1.0-beta-382 135 5/21/2024
1.1.0-beta-370 132 5/8/2024
1.1.0-beta-355 135 5/7/2024
1.1.0-beta-349 129 5/7/2024
1.1.0-beta-346 129 5/7/2024
1.1.0-beta-340 133 5/7/2024
1.1.0-beta-323 125 5/6/2024
1.0.7 340 4/11/2024
1.0.7-beta-312 130 4/26/2024
1.0.7-beta-299 145 4/14/2024
1.0.7-beta-296 129 4/14/2024
1.0.7-beta-287 123 4/11/2024
1.0.7-beta-282 127 4/11/2024
1.0.7-beta-280 133 4/10/2024
1.0.7-beta-278 126 4/10/2024
1.0.7-beta-276 122 4/10/2024
1.0.7-beta-274 146 4/9/2024
1.0.7-beta-272 136 4/9/2024
1.0.6 172 3/21/2024
1.0.6-beta-266 129 3/21/2024
1.0.6-beta-260 128 3/21/2024
1.0.5 215 3/10/2024
1.0.5-prerelease-20240301-0... 113 3/1/2024
1.0.5-beta-227 133 3/10/2024
1.0.5-beta-221 141 3/9/2024
1.0.5-beta-214 139 3/9/2024
1.0.5-beta-208 135 3/1/2024
1.0.5-beta-206 131 3/1/2024
1.0.4 135 2/29/2024
1.0.4-prerelease-20240229-1... 90 2/29/2024
1.0.4-prerelease-20240228-0... 89 2/28/2024
1.0.4-prerelease-20240226-1... 110 2/26/2024