Skip to content

A sandbox utilizing dotnet 8.0 c# 12 as a playground to prototype and do interesting and bag of chips kinds of things.

Notifications You must be signed in to change notification settings

bsampica/dotnet-sandbox

Repository files navigation

dotnet-sandbox

This is a personal playground, IE: Sandbox, to test and prototype code in an operating environment. This is not meant to be production level code, but if some of the ideas in here, examples, or techniques; then use them as you wish!

Setup

Clone the repository:

git clone git@github.com:bsampica/dotnet-sandbox.git     

or

git clone https://github.com/bsampica/dotnet-sandbox.git

Install the dependencies

dotnet restore
dotnet run

URL Access

http://localhost:5000/swagger
http://localhost:5000/hangfire

This project depends on:

Note, these dependencies should install with dotnet restore.

Development Environment

Its being developed in Visual Studio Code, and I've tested it with Visual Studio 2022, and JetBrains Rider.

Special Notation

Non-Standard Method Decorators

In the HangfireJobController, you'll notice that a method is annotated with the following:

[ApiExplorerSettings(IgnoreApi = true)]

I like to refer to this as Configuration over Convention Common Sense.

Swagger will attempt to map any public method on the controller, but in this case will fail because it's not decorated with [HttpPost] or [HttpGet] ..etc. It's not callable over HTTP and not meant to be.

The full method is

[ApiExplorerSettings(IgnoreApi = true)]
public async Task BackgroundWork(int jobParameter CancellationToken token)
{
    // Simulate some work with a delay
    await Task.Delay(TimeSpan.FromMinutes(1), token);
    Console.WriteLine($"Running Job: {jobParameter}");
}

This prevents Swagger and Swashbuckle from attempting to discover this method.

It's simply a helper function inside the controller. In a production product you'd probably have a helper class located somewhere else, or do this work in the next layer down.

In Memory Databases (Hangfire)

As mentioned above, this uses an extension of hangfire written by the Hangfire Team. For testing, seeding, and job processing, while on the development box; Using an InMemory database is AWESOME.

You should be aware of a couple of things though.

  • It will increase your app startup time slightly, depending on your configuration.
  • It will wipe out all your jobs every time the application shuts down.
  • Not all of the features of a full fledged SQL database are available to an InMemory database. I haven't run into any issues, but your mileage my vary...
  • It's FAST. I dont have timings, (note to self, get timings), but InMemory job storage is quick.

API Methods

Methodology

The main methodology for this project follows typical convention in a webApi. The url follows

http://basepath:port/api/[method]/[parameter]

Example

Main Entrypoint

http://localhost:5000/api/QueueJob

This will create a single background job. the jobDelaySeconds determines the amount of time the background job will "pause" - during its execution. This will simulate the "work" being done in the background.

Parameter

jobDelaySeconds | [integer]

Second Entrypoint

http://localhost:5000/api/QueueMultipleJobs

this will create multiple background jobs. Internally it runs a foreach loop and adds them in quick succession one after another.

Parameters

jobDelaySeconds | [integer]

Same as above, the delay inside the job when it's running.

numOfJobs | [integer]

The number of jobs to create.

About

A sandbox utilizing dotnet 8.0 c# 12 as a playground to prototype and do interesting and bag of chips kinds of things.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages