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!
git clone git@github.com:bsampica/dotnet-sandbox.git
or
git clone https://github.com/bsampica/dotnet-sandbox.git
dotnet restore
dotnet run
http://localhost:5000/swagger
http://localhost:5000/hangfire
This project depends on:
- Microsoft WebAPI
- .NET 8.0
- C# 12.0 with Advanced Features enabled
- git for windows (command line)
- HangFire
- Hangfire.InMemoryStorage
Its being developed in Visual Studio Code, and I've tested it with Visual Studio 2022, and JetBrains Rider.
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.
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.
The main methodology for this project follows typical convention in a webApi. The url follows
http://basepath:port/api/[method]/[parameter]
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.
jobDelaySeconds | [integer]
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.
jobDelaySeconds | [integer]
Same as above, the delay inside the job when it's running.
numOfJobs | [integer]
The number of jobs to create.