2019-01-21 17:33:20 +08:00
|
|
|
|
using Bootstrap.DataAccess;
|
|
|
|
|
using Longbow.Web.Mvc;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Net.Http;
|
|
|
|
|
using Xunit;
|
|
|
|
|
|
2019-05-15 00:22:13 +08:00
|
|
|
|
namespace Bootstrap.Admin.Api.SqlServer
|
2019-01-21 17:33:20 +08:00
|
|
|
|
{
|
|
|
|
|
public class UsersTest : ControllerTest
|
|
|
|
|
{
|
|
|
|
|
public UsersTest(BAWebHost factory) : base(factory, "api/Users") { }
|
|
|
|
|
|
|
|
|
|
[Fact]
|
|
|
|
|
public async void Option_Ok()
|
|
|
|
|
{
|
|
|
|
|
var req = new HttpRequestMessage(HttpMethod.Options, "Users");
|
|
|
|
|
var resp = await Client.SendAsync(req);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Fact]
|
|
|
|
|
public async void Get_Ok()
|
|
|
|
|
{
|
|
|
|
|
// 菜单 系统菜单 系统使用条件
|
|
|
|
|
var query = "?sort=DisplayName&order=asc&offset=0&limit=20&name=Admin&displayName=Administrator&_=1547628247338";
|
|
|
|
|
var qd = await Client.GetAsJsonAsync<QueryData<object>>(query);
|
|
|
|
|
Assert.Single(qd.rows);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Fact]
|
|
|
|
|
public async void PostAndDelete_Ok()
|
|
|
|
|
{
|
|
|
|
|
var user = new User();
|
|
|
|
|
user.Delete(user.Retrieves().Where(usr => usr.UserName == "UnitTest-Delete").Select(usr => usr.Id));
|
|
|
|
|
|
2019-03-15 18:59:55 +08:00
|
|
|
|
var nusr = new User { UserName = "UnitTest_Delete", Password = "1", DisplayName = "DisplayName", ApprovedBy = "System", ApprovedTime = DateTime.Now, Description = "Desc", Icon = "default.jpg" };
|
2019-01-21 17:33:20 +08:00
|
|
|
|
var resp = await Client.PostAsJsonAsync<User, bool>("", nusr);
|
|
|
|
|
Assert.True(resp);
|
|
|
|
|
|
|
|
|
|
nusr.Id = user.Retrieves().First(u => u.UserName == nusr.UserName).Id;
|
|
|
|
|
resp = await Client.PostAsJsonAsync<User, bool>(nusr);
|
|
|
|
|
Assert.True(resp);
|
|
|
|
|
|
|
|
|
|
var ids = user.Retrieves().Where(d => d.UserName == nusr.UserName).Select(d => d.Id);
|
|
|
|
|
Assert.True(await Client.DeleteAsJsonAsync<IEnumerable<string>, bool>(ids));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Fact]
|
|
|
|
|
public async void PostById_Ok()
|
|
|
|
|
{
|
|
|
|
|
var rid = new Role().Retrieves().Where(r => r.RoleName == "Administrators").First().Id;
|
|
|
|
|
|
|
|
|
|
var ret = await Client.PostAsJsonAsync<string, IEnumerable<object>>($"{rid}?type=role", string.Empty);
|
|
|
|
|
Assert.NotNull(ret);
|
|
|
|
|
|
|
|
|
|
var gid = new Group().Retrieves().Where(r => r.GroupName == "Admin").First().Id;
|
|
|
|
|
ret = await Client.PostAsJsonAsync<string, IEnumerable<object>>($"{gid}?type=group", string.Empty);
|
|
|
|
|
Assert.NotNull(ret);
|
2019-03-05 14:53:34 +08:00
|
|
|
|
|
|
|
|
|
ret = await Client.PostAsJsonAsync<string, IEnumerable<object>>("UnitTest?type=reset", string.Empty);
|
|
|
|
|
Assert.NotNull(ret);
|
2019-01-21 17:33:20 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Fact]
|
|
|
|
|
public async void PutById_Ok()
|
|
|
|
|
{
|
|
|
|
|
var ids = new User().Retrieves().Where(u => u.UserName == "Admin").Select(u => u.Id);
|
|
|
|
|
var gid = new Group().Retrieves().Where(r => r.GroupName == "Admin").First().Id;
|
|
|
|
|
var ret = await Client.PutAsJsonAsync<IEnumerable<string>, bool>($"{gid}?type=group", ids);
|
|
|
|
|
Assert.True(ret);
|
|
|
|
|
|
|
|
|
|
var rid = new Role().Retrieves().Where(r => r.RoleName == "Administrators").First().Id;
|
|
|
|
|
ret = await Client.PutAsJsonAsync<IEnumerable<string>, bool>($"{rid}?type=role", ids);
|
|
|
|
|
Assert.True(ret);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|