186 lines
7.3 KiB
C#
186 lines
7.3 KiB
C#
using Manager.Services;
|
|
using ManagerService.Controllers;
|
|
using ManagerService.Data;
|
|
using ManagerService.DTOs;
|
|
using ManagerService.Helpers;
|
|
using ManagerService.Tests.Infrastructure;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using Microsoft.Extensions.Logging.Abstractions;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using Xunit;
|
|
|
|
namespace ManagerService.Tests.Controllers
|
|
{
|
|
public class UserControllerTests
|
|
{
|
|
private UserController BuildController(MyInfoMateDbContext db, string callerRole = "Manager.superadmin", string callerInstanceId = "inst-test")
|
|
{
|
|
var cfg = FakeMongoConfig.Create();
|
|
var userService = new UserDatabaseService(cfg);
|
|
var profileLogic = new ProfileLogic(NullLogger<ProfileLogic>.Instance);
|
|
|
|
var controller = new UserController(
|
|
NullLogger<UserController>.Instance,
|
|
userService,
|
|
profileLogic,
|
|
db);
|
|
|
|
FakeUser.SetUser(controller, FakeUser.Create(callerRole, callerInstanceId));
|
|
return controller;
|
|
}
|
|
|
|
private static UserDetailDTO MakeNewUser(string email, string instanceId = "inst-test", UserRole role = UserRole.ContentEditor) =>
|
|
new UserDetailDTO
|
|
{
|
|
email = email,
|
|
firstName = "Test",
|
|
lastName = "User",
|
|
instanceId = instanceId,
|
|
password = "password123",
|
|
role = role
|
|
};
|
|
|
|
// ── GET ──────────────────────────────────────────────────────────────
|
|
|
|
[Fact]
|
|
public void Get_SuperAdmin_SeesAllInstances()
|
|
{
|
|
using var db = DbContextFactory.Create();
|
|
db.Users.AddRange(
|
|
new User { Id = "u1", Email = "a@a.be", Password = "x", LastName = "A", Token = "t1", InstanceId = "inst1" },
|
|
new User { Id = "u2", Email = "b@b.be", Password = "x", LastName = "B", Token = "t2", InstanceId = "inst2" }
|
|
);
|
|
db.SaveChanges();
|
|
|
|
var result = BuildController(db, "Manager.superadmin").Get();
|
|
|
|
var ok = Assert.IsType<OkObjectResult>(result);
|
|
var users = Assert.IsAssignableFrom<IEnumerable<UserDetailDTO>>(ok.Value);
|
|
Assert.Equal(2, users.Count());
|
|
}
|
|
|
|
[Fact]
|
|
public void Get_InstanceAdmin_SeesOnlyOwnInstance()
|
|
{
|
|
using var db = DbContextFactory.Create();
|
|
db.Users.AddRange(
|
|
new User { Id = "u1", Email = "a@a.be", Password = "x", LastName = "A", Token = "t1", InstanceId = "inst-test" },
|
|
new User { Id = "u2", Email = "b@b.be", Password = "x", LastName = "B", Token = "t2", InstanceId = "other-inst" }
|
|
);
|
|
db.SaveChanges();
|
|
|
|
var result = BuildController(db, "Manager.instanceadmin", "inst-test").Get();
|
|
|
|
var ok = Assert.IsType<OkObjectResult>(result);
|
|
var users = Assert.IsAssignableFrom<IEnumerable<UserDetailDTO>>(ok.Value);
|
|
Assert.Equal(1, users.Count());
|
|
Assert.All(users, u => Assert.Equal("inst-test", u.instanceId));
|
|
}
|
|
|
|
// ── CREATE ───────────────────────────────────────────────────────────
|
|
|
|
[Fact]
|
|
public void CreateUser_DuplicateEmail_Returns409()
|
|
{
|
|
using var db = DbContextFactory.Create();
|
|
db.Users.Add(new User { Id = "u1", Email = "dup@a.be", Password = "x", LastName = "A", Token = "t1", InstanceId = "inst-test" });
|
|
db.SaveChanges();
|
|
|
|
var result = BuildController(db).CreateUser(MakeNewUser("dup@a.be"));
|
|
|
|
Assert.IsType<ConflictObjectResult>(result);
|
|
}
|
|
|
|
[Fact]
|
|
public void CreateUser_InstanceAdminCreatingInstanceAdmin_Returns403()
|
|
{
|
|
// InstanceAdmin (role=1) ne peut pas créer SuperAdmin (role=0)
|
|
using var db = DbContextFactory.Create();
|
|
|
|
var result = BuildController(db, "Manager.instanceadmin")
|
|
.CreateUser(MakeNewUser("new@a.be", role: UserRole.SuperAdmin));
|
|
|
|
var statusResult = Assert.IsType<ObjectResult>(result);
|
|
Assert.Equal(403, statusResult.StatusCode);
|
|
}
|
|
|
|
[Fact]
|
|
public void CreateUser_ValidDto_HashesPassword()
|
|
{
|
|
using var db = DbContextFactory.Create();
|
|
|
|
var result = BuildController(db).CreateUser(MakeNewUser("new@a.be"));
|
|
|
|
Assert.IsType<OkObjectResult>(result);
|
|
var user = db.Users.First();
|
|
Assert.NotEqual("password123", user.Password); // doit être haché
|
|
}
|
|
|
|
[Fact]
|
|
public void CreateUser_NullPassword_Returns400()
|
|
{
|
|
using var db = DbContextFactory.Create();
|
|
|
|
var dto = new UserDetailDTO { email = "x@x.be", lastName = "X", instanceId = "inst-test", password = null };
|
|
var result = BuildController(db).CreateUser(dto);
|
|
|
|
Assert.IsType<BadRequestObjectResult>(result);
|
|
}
|
|
|
|
// ── UPDATE ───────────────────────────────────────────────────────────
|
|
|
|
[Fact]
|
|
public void UpdateUser_UnknownId_Returns404()
|
|
{
|
|
using var db = DbContextFactory.Create();
|
|
|
|
var result = BuildController(db).UpdateUser(new UserDetailDTO { id = "unknown", firstName = "X", lastName = "Y" });
|
|
|
|
Assert.IsType<NotFoundObjectResult>(result);
|
|
}
|
|
|
|
[Fact]
|
|
public void UpdateUser_ExistingUser_UpdatesName()
|
|
{
|
|
using var db = DbContextFactory.Create();
|
|
db.Users.Add(new User { Id = "u1", Email = "a@a.be", Password = "x", LastName = "Old", Token = "t1", InstanceId = "inst-test" });
|
|
db.SaveChanges();
|
|
|
|
var result = BuildController(db).UpdateUser(new UserDetailDTO { id = "u1", firstName = "New", lastName = "Name" });
|
|
|
|
Assert.IsType<OkObjectResult>(result);
|
|
var user = db.Users.First();
|
|
Assert.Equal("New", user.FirstName);
|
|
Assert.Equal("Name", user.LastName);
|
|
}
|
|
|
|
// ── DELETE ───────────────────────────────────────────────────────────
|
|
|
|
[Fact]
|
|
public void DeleteUser_ExistingUser_Returns202()
|
|
{
|
|
using var db = DbContextFactory.Create();
|
|
db.Users.Add(new User { Id = "u1", Email = "a@a.be", Password = "x", LastName = "A", Token = "t1", InstanceId = "inst-test" });
|
|
db.SaveChanges();
|
|
|
|
var result = BuildController(db).DeleteUser("u1");
|
|
|
|
var statusResult = Assert.IsType<ObjectResult>(result);
|
|
Assert.Equal(202, statusResult.StatusCode);
|
|
Assert.Equal(0, db.Users.Count());
|
|
}
|
|
|
|
[Fact]
|
|
public void DeleteUser_UnknownId_Returns404()
|
|
{
|
|
using var db = DbContextFactory.Create();
|
|
|
|
var result = BuildController(db).DeleteUser("unknown");
|
|
|
|
Assert.IsType<NotFoundObjectResult>(result);
|
|
}
|
|
}
|
|
}
|