GithubHelp home page GithubHelp logo

minhas-tarefas-cs-web's Introduction

minhas-tarefas-cs-web

Uma aplicação em C# (web) com Minimal APIs, EFCore 6, MySQL e Pomelo

Build and test

OpenAPI (Swagger)

Pacote:

dotnet add package Swashbuckle.AspNetCore

Código:

builder.Services.AddSwaggerGen();
builder.Services.AddEndpointsApiExplorer();
...
app.UseSwagger();
app.UseSwaggerUI();

Arquivos estáticos

Código:

app.UseDefaultFiles();
app.UseStaticFiles();

EntityFramework Core 6 (MySQL com Pomelo)

Banco: https://github.com/ermogenes/minhas-tarefas-mysql

Para subir o MySQL com Docker:

docker run -p 3306:3306 -e MYSQL_ROOT_PASSWORD=1234 mysql:8.0.28

Foi utilizada a lib Pomelo (Pomelo.EntityFrameworkCore.MySql) em vez do Connector/NET oficial da Oracle, devido ao suporte simplificado a diferentes versões do MySQL.

Comandos utilizados para fazer o scaffolding:

dotnet tool install --global dotnet-ef
dotnet tool update --global dotnet-ef

dotnet add package Microsoft.EntityFrameworkCore
dotnet add package Microsoft.EntityFrameworkCore.Design
dotnet add package Pomelo.EntityFrameworkCore.MySql

dotnet ef dbcontext scaffold "server=localhost;port=3306;uid=root;pwd=1234;database=tarefas" Pomelo.EntityFrameworkCore.MySql -o db -f --no-pluralize

String de conexão transferida de tarefasContext.OnConfiguring para appsettings.json:

"ConnectionStrings": {
    "tarefasConnection": "server=localhost;port=3306;uid=root;pwd=1234;database=tarefas"
}

Exemplo:

...
builder.Services.AddDbContext<tarefasContext>(opt =>
{
    string connectionString = builder.Configuration.GetConnectionString("tarefasConnection");
    var serverVersion = ServerVersion.AutoDetect(connectionString);
    opt.UseMySql(connectionString, serverVersion);
});
...
app.MapGet("/api/tarefas", ([FromServices] tarefasContext _db) =>
{
    return Results.Ok(_db.Tarefa.ToList<Tarefa>());
});
...

Segurança

Hashing de senha:

dotnet add package CryptoHelper

Autenticação e autorização com JWT:

dotnet add package Microsoft.AspNetCore.Authentication.JwtBearer

Loop JSON

builder.Services.Configure<Microsoft.AspNetCore.Http.Json.JsonOptions>(opt =>
{
  opt.SerializerOptions.ReferenceHandler = ReferenceHandler.IgnoreCycles;
});

Solução

dotnet new sln

Testes

Criar a solução:

dotnet new xunit -o Tarefas.Tests

Adicionar a referência do projeto nos testes:

dotnet add reference ../Tarefas/Tarefas.csproj

Adicionar os pacotes:

dotnet add package Microsoft.AspNetCore.Mvc.Testing

Tornar o Program do projeto acessível aos testes:

  <ItemGroup>
    <InternalsVisibleTo Include="Tarefas.Tests" />
  </ItemGroup>

Criar uma instância de WebApplicationFactory<Program>. Executando CreateClient() você tem acesso a uma instância de Program.

É possível sobrescrever IHost CreateHost(IHostBuilder builder) e alterar como desejar os objetos injetados.

O exemplo remove o repositório injetado e injeta um novo que usa outro contexto (no app é MySQL, nos testes é Sqlite em memória). Também faz uma carga inicial (que funciona como Arrange dos testes).

Outra estratégia possível é não usar repositório, e reinjetar diretamente um contexto. Não é recomendado utilizar In Memory Databases para testes de integração.

minhas-tarefas-cs-web's People

Contributors

ermogenes avatar

Watchers

James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.