BootstrapAdmin/test/UnitTest/Bootstrap.Admin/Api/SQLServer/NewTest.cs

63 lines
1.7 KiB
C#

using Bootstrap.DataAccess;
using System.Collections.Generic;
using System.Linq;
using Xunit;
namespace Bootstrap.Admin.Api.SqlServer
{
public class NewTest : ControllerTest
{
public NewTest(BAWebHost factory) : base(factory, "api/New") { }
[Fact]
public async void Get_Ok()
{
var nusr = InsertNewUser();
var resp = await Client.GetAsJsonAsync<IEnumerable<object>>();
Assert.NotEmpty(resp);
// 删除新用户
DeleteUnitTestUser();
}
[Fact]
public async void Put_Ok()
{
DeleteUnitTestUser();
var nusr = InsertNewUser();
// Approve
nusr.UserStatus = UserStates.ApproveUser;
var resp = await Client.PutAsJsonAsync<User, bool>(nusr);
Assert.True(resp);
// 删除新用户
UserHelper.Delete(new string[] { nusr.Id });
// Reject
nusr = InsertNewUser();
nusr.UserStatus = UserStates.RejectUser;
resp = await Client.PutAsJsonAsync<User, bool>(nusr);
Assert.True(resp);
// 删除新用户
DeleteUnitTestUser();
}
private User InsertNewUser()
{
// 插入新用户
var nusr = new User() { UserName = "UnitTest_New", DisplayName = "UnitTest", Password = "1", Description = "UnitTest" };
Assert.True(UserHelper.Save(nusr));
return nusr;
}
private void DeleteUnitTestUser()
{
var ids = UserHelper.RetrieveNewUsers().Where(u => u.UserName == "UnitTest_New").Select(u => u.Id);
UserHelper.Delete(ids);
}
}
}