// Copyright (c) .NET Foundation. All rights reserved. // Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information. using System.Collections.Generic; using System.Net; using System.Net.Http; using System.Threading.Tasks; using Xunit; namespace Microsoft.AspNetCore.Mvc.FunctionalTests { public class RazorPageModelTest : IClassFixture> { public RazorPageModelTest(MvcTestFixture fixture) { Client = fixture.Client; } public HttpClient Client { get; } [Fact] public async Task Page_TryUpdateModelAsync_Success() { // Arrange var request = new HttpRequestMessage(HttpMethod.Post, "Pages/TryUpdateModel/10") { Content = new FormUrlEncodedContent(new KeyValuePair[] { new KeyValuePair("Name", "Overriden"), new KeyValuePair("Age", "25"), }) }; await AddAntiforgeryHeaders(request); // Act var response = await Client.SendAsync(request); // Assert Assert.Equal(HttpStatusCode.OK, response.StatusCode); var content = await response.Content.ReadAsStringAsync(); Assert.Contains("Updated: True", content); Assert.Contains("Name = Overriden", content); } [Fact] public async Task Page_TryValidateModel_Success() { // Arrange var request = new HttpRequestMessage(HttpMethod.Post, "Pages/TryValidateModel/10") { Content = new FormUrlEncodedContent(new KeyValuePair[] { new KeyValuePair("Name", "Foo"), new KeyValuePair("Age", "25"), }) }; await AddAntiforgeryHeaders(request); // Act var response = await Client.SendAsync(request); // Assert Assert.Equal(HttpStatusCode.OK, response.StatusCode); var content = await response.Content.ReadAsStringAsync(); Assert.Contains("Validation: success", content.Trim()); } [Fact] public async Task Page_TryValidateModel_TooLong() { // Arrange var request = new HttpRequestMessage(HttpMethod.Post, "Pages/TryValidateModel/10") { Content = new FormUrlEncodedContent(new KeyValuePair[] { new KeyValuePair("Name", "Foo"), new KeyValuePair("Age", "200"), }) }; await AddAntiforgeryHeaders(request); // Act var response = await Client.SendAsync(request); // Assert Assert.Equal(HttpStatusCode.OK, response.StatusCode); var content = await response.Content.ReadAsStringAsync(); Assert.Contains("Validation: fail", content); Assert.Contains("The field Age must be between 0 and 99.", content); } [Fact] public async Task PageModel_TryUpdateModelAsync_Success() { // Arrange var request = new HttpRequestMessage(HttpMethod.Post, "Pages/TryUpdateModelPageModel/10") { Content = new FormUrlEncodedContent(new KeyValuePair[] { new KeyValuePair("Name", "Overriden"), new KeyValuePair("Age", "25"), }) }; await AddAntiforgeryHeaders(request); // Act var response = await Client.SendAsync(request); // Assert Assert.Equal(HttpStatusCode.OK, response.StatusCode); var content = await response.Content.ReadAsStringAsync(); Assert.Contains("Updated: True", content); Assert.Contains("Name = Overriden", content); } [Fact] public async Task PageModel_TryValidateModel_Success() { // Arrange var request = new HttpRequestMessage(HttpMethod.Post, "Pages/TryValidateModelPageModel/10") { Content = new FormUrlEncodedContent(new KeyValuePair[] { new KeyValuePair("Name", "Foo"), new KeyValuePair("Age", "25"), }) }; await AddAntiforgeryHeaders(request); // Act var response = await Client.SendAsync(request); // Assert Assert.Equal(HttpStatusCode.OK, response.StatusCode); var content = await response.Content.ReadAsStringAsync(); Assert.Contains("Validation: success", content.Trim()); } [Fact] public async Task PageModel_TryValidateModel_TooLong() { // Arrange var request = new HttpRequestMessage(HttpMethod.Post, "Pages/TryValidateModelPageModel/10") { Content = new FormUrlEncodedContent(new KeyValuePair[] { new KeyValuePair("Name", "Foo"), new KeyValuePair("Age", "200"), }) }; await AddAntiforgeryHeaders(request); // Act var response = await Client.SendAsync(request); // Assert Assert.Equal(HttpStatusCode.OK, response.StatusCode); var content = await response.Content.ReadAsStringAsync(); Assert.Contains("Validation: fail", content); Assert.Contains("The field Age must be between 0 and 99.", content); } private async Task AddAntiforgeryHeaders(HttpRequestMessage request) { var getResponse = await Client.GetAsync(request.RequestUri); Assert.Equal(HttpStatusCode.OK, getResponse.StatusCode); var getResponseBody = await getResponse.Content.ReadAsStringAsync(); var formToken = AntiforgeryTestHelper.RetrieveAntiforgeryToken(getResponseBody, ""); var cookie = AntiforgeryTestHelper.RetrieveAntiforgeryCookie(getResponse); request.Headers.Add("Cookie", cookie.Key + "=" + cookie.Value); request.Headers.Add("RequestVerificationToken", formToken); } } }