234 lines
9.2 KiB
C#
234 lines
9.2 KiB
C#
//// Copyright (c) Microsoft Open Technologies, Inc.
|
|
//// All Rights Reserved
|
|
////
|
|
//// Licensed under the Apache License, Version 2.0 (the "License");
|
|
//// you may not use this file except in compliance with the License.
|
|
//// You may obtain a copy of the License at
|
|
////
|
|
//// http://www.apache.org/licenses/LICENSE-2.0
|
|
////
|
|
//// THIS CODE IS PROVIDED *AS IS* BASIS, WITHOUT WARRANTIES OR
|
|
//// CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING
|
|
//// WITHOUT LIMITATION ANY IMPLIED WARRANTIES OR CONDITIONS OF
|
|
//// TITLE, FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABLITY OR
|
|
//// NON-INFRINGEMENT.
|
|
//// See the Apache 2 License for the specific language governing
|
|
//// permissions and limitations under the License.
|
|
|
|
using Microsoft.AspNet.Builder;
|
|
using Microsoft.AspNet.Identity.Test;
|
|
using Microsoft.AspNet.Testing;
|
|
using Microsoft.Data.Entity;
|
|
using Microsoft.Data.Entity.Metadata;
|
|
using Microsoft.Data.Entity.InMemory;
|
|
using Microsoft.Data.Entity.SqlServer;
|
|
using Microsoft.Framework.DependencyInjection;
|
|
using Microsoft.Framework.DependencyInjection.Fallback;
|
|
using System;
|
|
using System.Linq;
|
|
using System.Security.Claims;
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
using Xunit;
|
|
|
|
namespace Microsoft.AspNet.Identity.Entity.Test
|
|
{
|
|
public class SqlUserStoreTest
|
|
{
|
|
public class ApplicationUser : User { }
|
|
public class ApplicationUserManager : UserManager<ApplicationUser>
|
|
{
|
|
public ApplicationUserManager(IServiceProvider services, IUserStore<ApplicationUser> store, IOptionsAccessor<IdentityOptions> options) : base(services, store, options) { }
|
|
}
|
|
public class ApplicationRoleManager : RoleManager<EntityRole>
|
|
{
|
|
public ApplicationRoleManager(IServiceProvider services, IRoleStore<EntityRole> store) : base(services, store) { }
|
|
}
|
|
|
|
public class ApplicationDbContext : IdentitySqlContext<ApplicationUser>
|
|
{
|
|
public ApplicationDbContext(IServiceProvider services) : base(services) { }
|
|
}
|
|
|
|
[Fact]
|
|
public async Task EnsureStartupUsageWorks()
|
|
{
|
|
IBuilder builder = new Microsoft.AspNet.Builder.Builder(new ServiceCollection().BuildServiceProvider());
|
|
|
|
//builder.UseServices(services => services.AddIdentity<ApplicationUser>(s =>
|
|
// s.AddEntity<ApplicationDbContext>()
|
|
//{
|
|
|
|
builder.UseServices(services =>
|
|
{
|
|
services.AddEntityFramework();
|
|
services.AddInstance<DbContext>(CreateAppContext());
|
|
services.AddIdentity<ApplicationUser>(s =>
|
|
{
|
|
s.AddEntity();
|
|
s.AddUserManager<ApplicationUserManager>();
|
|
});
|
|
});
|
|
|
|
var userStore = builder.ApplicationServices.GetService<IUserStore<ApplicationUser>>();
|
|
var userManager = builder.ApplicationServices.GetService<ApplicationUserManager>();
|
|
|
|
Assert.NotNull(userStore);
|
|
Assert.NotNull(userManager);
|
|
|
|
const string userName = "admin";
|
|
const string password = "1qaz@WSX";
|
|
var user = new ApplicationUser { UserName = userName };
|
|
IdentityResultAssert.IsSuccess(await userManager.CreateAsync(user, password));
|
|
IdentityResultAssert.IsSuccess(await userManager.DeleteAsync(user));
|
|
}
|
|
|
|
[Fact]
|
|
public void CanCreateUserUsingEF()
|
|
{
|
|
using (var db = CreateContext())
|
|
{
|
|
var guid = Guid.NewGuid().ToString();
|
|
db.Users.Add(new User {Id = guid, UserName = guid});
|
|
db.SaveChanges();
|
|
Assert.NotNull(db.Users.FirstOrDefault(u => u.UserName == guid));
|
|
}
|
|
}
|
|
|
|
public static IdentitySqlContext CreateContext()
|
|
{
|
|
var serviceProvider = new ServiceCollection()
|
|
.AddEntityFramework(s => s.AddSqlServer())
|
|
.BuildServiceProvider();
|
|
|
|
var db = new IdentitySqlContext(serviceProvider);
|
|
|
|
// TODO: Recreate DB, doesn't support String ID or Identity context yet
|
|
if (!db.Database.Exists())
|
|
{
|
|
db.Database.Create();
|
|
}
|
|
|
|
// TODO: CreateAsync DB?
|
|
return db;
|
|
}
|
|
|
|
public static ApplicationDbContext CreateAppContext()
|
|
{
|
|
var serviceProvider = new ServiceCollection()
|
|
.AddEntityFramework(s => s.AddSqlServer())
|
|
.BuildServiceProvider();
|
|
|
|
var db = new ApplicationDbContext(serviceProvider);
|
|
|
|
// TODO: Recreate DB, doesn't support String ID or Identity context yet
|
|
if (!db.Database.Exists())
|
|
{
|
|
db.Database.Create();
|
|
}
|
|
|
|
// TODO: CreateAsync DB?
|
|
return db;
|
|
}
|
|
|
|
public static UserManager<User> CreateManager(DbContext context)
|
|
{
|
|
var services = new ServiceCollection();
|
|
services.AddTransient<IUserValidator<User>, UserValidator<User>>();
|
|
services.AddTransient<IPasswordValidator<User>, PasswordValidator<User>>();
|
|
//services.AddInstance<IUserStore<User>>(new UserStore<User>(context));
|
|
//services.AddSingleton<UserManager<User>>();
|
|
var options = new IdentityOptions
|
|
{
|
|
Password = new PasswordOptions
|
|
{
|
|
RequireDigit = false,
|
|
RequireLowercase = false,
|
|
RequireNonLetterOrDigit = false,
|
|
RequireUppercase = false
|
|
},
|
|
User = new UserOptions
|
|
{
|
|
AllowOnlyAlphanumericNames = false
|
|
}
|
|
|
|
};
|
|
var optionsAccessor = new OptionsAccessor<IdentityOptions>(new[] { new TestIdentityFactory.TestSetup(options) });
|
|
//services.AddInstance<IOptionsAccessor<IdentityOptions>>(new OptionsAccessor<IdentityOptions>(new[] { new TestSetup(options) }));
|
|
//return services.BuildServiceProvider().GetService<UserManager<User>>();
|
|
return new UserManager<User>(services.BuildServiceProvider(), new UserStore<User>(context), optionsAccessor);
|
|
}
|
|
|
|
public static UserManager<User> CreateManager()
|
|
{
|
|
return CreateManager(CreateContext());
|
|
}
|
|
|
|
[Fact]
|
|
public async Task CanCreateUsingManager()
|
|
{
|
|
var manager = CreateManager();
|
|
var guid = Guid.NewGuid().ToString();
|
|
var user = new User { UserName = "New"+guid };
|
|
IdentityResultAssert.IsSuccess(await manager.CreateAsync(user));
|
|
IdentityResultAssert.IsSuccess(await manager.DeleteAsync(user));
|
|
}
|
|
|
|
[Fact]
|
|
public async Task CanDeleteUser()
|
|
{
|
|
var manager = CreateManager();
|
|
var user = new User("DeleteAsync");
|
|
IdentityResultAssert.IsSuccess(await manager.CreateAsync(user));
|
|
IdentityResultAssert.IsSuccess(await manager.DeleteAsync(user));
|
|
Assert.Null(await manager.FindByIdAsync(user.Id));
|
|
}
|
|
|
|
[Fact]
|
|
public async Task CanUpdateUserName()
|
|
{
|
|
var manager = CreateManager();
|
|
var user = new User("UpdateAsync");
|
|
IdentityResultAssert.IsSuccess(await manager.CreateAsync(user));
|
|
Assert.Null(await manager.FindByNameAsync("New"));
|
|
user.UserName = "New";
|
|
IdentityResultAssert.IsSuccess(await manager.UpdateAsync(user));
|
|
Assert.NotNull(await manager.FindByNameAsync("New"));
|
|
Assert.Null(await manager.FindByNameAsync("UpdateAsync"));
|
|
IdentityResultAssert.IsSuccess(await manager.DeleteAsync(user));
|
|
}
|
|
|
|
[Fact]
|
|
public async Task CanSetUserName()
|
|
{
|
|
var manager = CreateManager();
|
|
var user = new User("UpdateAsync");
|
|
IdentityResultAssert.IsSuccess(await manager.CreateAsync(user));
|
|
Assert.Null(await manager.FindByNameAsync("New"));
|
|
IdentityResultAssert.IsSuccess(await manager.SetUserNameAsync(user, "New"));
|
|
Assert.NotNull(await manager.FindByNameAsync("New"));
|
|
Assert.Null(await manager.FindByNameAsync("UpdateAsync"));
|
|
IdentityResultAssert.IsSuccess(await manager.DeleteAsync(user));
|
|
}
|
|
|
|
[Fact]
|
|
public async Task CanChangePassword()
|
|
{
|
|
var manager = TestIdentityFactory.CreateManager();
|
|
var user = new EntityUser("ChangePasswordTest");
|
|
const string password = "password";
|
|
const string newPassword = "newpassword";
|
|
IdentityResultAssert.IsSuccess(await manager.CreateAsync(user, password));
|
|
//Assert.Equal(manager.Users.Count(), 1);
|
|
//var stamp = user.SecurityStamp;
|
|
//Assert.NotNull(stamp);
|
|
IdentityResultAssert.IsSuccess(await manager.ChangePasswordAsync(user, password, newPassword));
|
|
Assert.Null(await manager.FindByUserNamePasswordAsync(user.UserName, password));
|
|
Assert.Equal(user, await manager.FindByUserNamePasswordAsync(user.UserName, newPassword));
|
|
//Assert.NotEqual(stamp, user.SecurityStamp);
|
|
IdentityResultAssert.IsSuccess(await manager.DeleteAsync(user));
|
|
}
|
|
|
|
}
|
|
}
|