本文整理匯總了C#中Nancy.Tests.Fakes.FakeHookedModule.RequiresClaims方法的典型用法代碼示例。如果您正苦於以下問題:C# FakeHookedModule.RequiresClaims方法的具體用法?C# FakeHookedModule.RequiresClaims怎麽用?C# FakeHookedModule.RequiresClaims使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Nancy.Tests.Fakes.FakeHookedModule
的用法示例。
在下文中一共展示了FakeHookedModule.RequiresClaims方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: Should_add_two_items_to_the_start_of_the_begin_pipeline_when_RequiresClaims_enabled
public void Should_add_two_items_to_the_start_of_the_begin_pipeline_when_RequiresClaims_enabled()
{
var module = new FakeHookedModule(A.Fake<BeforePipeline>());
module.RequiresClaims(new[] { string.Empty });
A.CallTo(() => module.Before.AddItemToStartOfPipeline(A<Func<NancyContext, Response>>.Ignored)).MustHaveHappened(Repeated.Exactly.Twice);
}
示例2: Should_return_forbidden_response_with_RequiresClaims_enabled_but_claims_key_missing
public void Should_return_forbidden_response_with_RequiresClaims_enabled_but_claims_key_missing()
{
var module = new FakeHookedModule(new BeforePipeline());
module.RequiresClaims(new[] { "Claim1" });
var context = new NancyContext();
context.Items[Nancy.Security.SecurityConventions.AuthenticatedUsernameKey] = "username";
var result = module.Before.Invoke(context);
result.ShouldNotBeNull();
result.StatusCode.ShouldEqual(HttpStatusCode.Forbidden);
}
示例3: Should_return_forbidden_response_with_RequiresClaims_enabled_but_claims_key_missing
public void Should_return_forbidden_response_with_RequiresClaims_enabled_but_claims_key_missing()
{
var module = new FakeHookedModule(new BeforePipeline());
module.RequiresClaims(new[] { "Claim1" });
var context = new NancyContext
{
CurrentUser = GetFakeUser("username")
};
var result = module.Before.Invoke(context);
result.ShouldNotBeNull();
result.StatusCode.ShouldEqual(HttpStatusCode.Forbidden);
}
示例4: Should_return_unauthorized_response_with_RequiresClaims_enabled_and_no_username
public void Should_return_unauthorized_response_with_RequiresClaims_enabled_and_no_username()
{
var module = new FakeHookedModule(new BeforePipeline());
module.RequiresClaims(new[] { string.Empty });
var result = module.Before.Invoke(new NancyContext());
result.ShouldNotBeNull();
result.StatusCode.ShouldEqual(HttpStatusCode.Unauthorized);
}
示例5: Should_return_unauthorized_response_with_RequiresClaims_enabled_and_blank_username
public void Should_return_unauthorized_response_with_RequiresClaims_enabled_and_blank_username()
{
var module = new FakeHookedModule(new BeforePipeline());
module.RequiresClaims(new[] { string.Empty });
var context = new NancyContext();
context.Items[Nancy.Security.SecurityConventions.AuthenticatedUsernameKey] = String.Empty;
var result = module.Before.Invoke(context);
result.ShouldNotBeNull();
result.StatusCode.ShouldEqual(HttpStatusCode.Unauthorized);
}
示例6: Should_return_null_with_RequiresClaims_and_all_claims_met
public void Should_return_null_with_RequiresClaims_and_all_claims_met()
{
var module = new FakeHookedModule(new BeforePipeline());
module.RequiresClaims(new[] { "Claim1", "Claim2" });
var context = new NancyContext();
context.Items[Nancy.Security.SecurityConventions.AuthenticatedUsernameKey] = "username";
context.Items[Nancy.Security.SecurityConventions.AuthenticatedClaimsKey] = new[] { "Claim1", "Claim2", "Claim3" };
var result = module.Before.Invoke(context);
result.ShouldBeNull();
}
示例7: Should_return_null_with_RequiresClaims_and_all_claims_met
public void Should_return_null_with_RequiresClaims_and_all_claims_met()
{
var module = new FakeHookedModule(new BeforePipeline());
module.RequiresClaims(new[] { "Claim1", "Claim2" });
var context = new NancyContext
{
CurrentUser = GetFakeUser("username", new[] {"Claim1", "Claim2", "Claim3"})
};
var result = module.Before.Invoke(context);
result.ShouldBeNull();
}
示例8: Should_return_unauthorized_response_with_RequiresClaims_enabled_and_blank_username
public void Should_return_unauthorized_response_with_RequiresClaims_enabled_and_blank_username()
{
var module = new FakeHookedModule(new BeforePipeline());
module.RequiresClaims(new[] { string.Empty });
var context = new NancyContext
{
CurrentUser = GetFakeUser(String.Empty)
};
var result = module.Before.Invoke(context, new CancellationToken());
result.Result.ShouldNotBeNull();
result.Result.StatusCode.ShouldEqual(HttpStatusCode.Unauthorized);
}
示例9: Should_return_forbidden_response_with_RequiresClaims_enabled_but_not_all_claims_met
public void Should_return_forbidden_response_with_RequiresClaims_enabled_but_not_all_claims_met()
{
var module = new FakeHookedModule(new BeforePipeline());
module.RequiresClaims(new[] { "Claim1", "Claim2" });
var context = new NancyContext
{
CurrentUser = GetFakeUser("username", new[] {"Claim2"})
};
var result = module.Before.Invoke(context, new CancellationToken());
result.Result.ShouldNotBeNull();
result.Result.StatusCode.ShouldEqual(HttpStatusCode.Forbidden);
}
示例10: Should_return_forbidden_response_with_RequiresClaims_enabled_but_nonmatching_claims
public void Should_return_forbidden_response_with_RequiresClaims_enabled_but_nonmatching_claims()
{
var module = new FakeHookedModule(new BeforePipeline());
module.RequiresClaims(c => c.Type == "Claim1");
var context = new NancyContext
{
CurrentUser = GetFakeUser(
"username",
new Claim("Claim2", string.Empty),
new Claim("Claim3", string.Empty))
};
var result = module.Before.Invoke(context, new CancellationToken());
result.Result.ShouldNotBeNull();
result.Result.StatusCode.ShouldEqual(HttpStatusCode.Forbidden);
}
示例11: Should_return_null_with_RequiresClaims_and_all_claims_met
public void Should_return_null_with_RequiresClaims_and_all_claims_met()
{
var module = new FakeHookedModule(new BeforePipeline());
module.RequiresClaims(c => c.Type == "Claim1", c => c.Type == "Claim2");
var context = new NancyContext
{
CurrentUser = GetFakeUser("username",
new Claim("Claim1", string.Empty),
new Claim("Claim2", string.Empty),
new Claim("Claim3", string.Empty))
};
var result = module.Before.Invoke(context, new CancellationToken());
result.Result.ShouldBeNull();
}