aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/DevHive.Tests/DevHive.Web.Tests/FeedController.Tests.cs98
-rw-r--r--src/DevHive.Tests/DevHive.Web.Tests/TechnologyController.Tests.cs2
-rw-r--r--src/DevHive.Web/Configurations/Mapping/FeedMappings.cs2
-rw-r--r--src/DevHive.Web/Controllers/FeedController.cs1
-rw-r--r--src/DevHive.Web/Models/Feed/ReadPageWebModel.cs2
5 files changed, 103 insertions, 2 deletions
diff --git a/src/DevHive.Tests/DevHive.Web.Tests/FeedController.Tests.cs b/src/DevHive.Tests/DevHive.Web.Tests/FeedController.Tests.cs
new file mode 100644
index 0000000..01f67e5
--- /dev/null
+++ b/src/DevHive.Tests/DevHive.Web.Tests/FeedController.Tests.cs
@@ -0,0 +1,98 @@
+using System;
+using System.Collections.Generic;
+using System.Threading.Tasks;
+using AutoMapper;
+using DevHive.Services.Interfaces;
+using DevHive.Services.Models;
+using DevHive.Web.Controllers;
+using DevHive.Web.Models.Comment;
+using DevHive.Web.Models.Feed;
+using DevHive.Web.Models.Post;
+using Microsoft.AspNetCore.Mvc;
+using Moq;
+using NUnit.Framework;
+
+namespace DevHive.Web.Tests
+{
+ [TestFixture]
+ public class FeedControllerTests
+ {
+ private Mock<IFeedService> FeedServiceMock { get; set; }
+ private Mock<IMapper> MapperMock { get; set; }
+ private FeedController FeedController { get; set; }
+
+ #region SetUp
+ [SetUp]
+ public void SetUp()
+ {
+ this.FeedServiceMock = new Mock<IFeedService>();
+ this.MapperMock = new Mock<IMapper>();
+ this.FeedController = new FeedController(this.FeedServiceMock.Object, this.MapperMock.Object);
+ }
+ #endregion
+
+ #region GetPosts
+ [Test]
+ public async Task GetPosts_ReturnsOkObjectResultWithCorrectReadPageWebModel_WhenPostsExist()
+ {
+ GetPageWebModel getPageWebModel = new GetPageWebModel { };
+ GetPageServiceModel getPageServiceModel = new GetPageServiceModel { };
+ ReadPageServiceModel readPageServiceModel = new ReadPageServiceModel { };
+ ReadPageWebModel readPageWebModel = new ReadPageWebModel
+ {
+ Posts = new List<ReadPostWebModel>
+ {
+ new ReadPostWebModel(),
+ new ReadPostWebModel(),
+ new ReadPostWebModel()
+ }
+ };
+
+ this.FeedServiceMock.Setup(p => p.GetPage(It.IsAny<GetPageServiceModel>())).Returns(Task.FromResult(readPageServiceModel));
+ this.MapperMock.Setup(p => p.Map<GetPageServiceModel>(It.IsAny<GetPageWebModel>())).Returns(getPageServiceModel);
+ this.MapperMock.Setup(p => p.Map<ReadPageWebModel>(It.IsAny<ReadPageServiceModel>())).Returns(readPageWebModel);
+
+ IActionResult result = await this.FeedController.GetPosts(Guid.Empty, getPageWebModel);
+
+ Assert.IsInstanceOf<OkObjectResult>(result);
+
+ OkObjectResult okObjectResult = result as OkObjectResult;
+ ReadPageWebModel resultModel = okObjectResult.Value as Models.Comment.ReadPageWebModel;
+
+ Assert.AreEqual(3, resultModel.Posts.Count);
+ }
+ #endregion
+
+ #region GetUserPosts
+ [Test]
+ public async Task GetUserPosts_GetsPostsOfUser_WhenTheyExist()
+ {
+ GetPageWebModel getPageWebModel = new GetPageWebModel { };
+ GetPageServiceModel getPageServiceModel = new GetPageServiceModel { };
+ ReadPageServiceModel readPageServiceModel = new ReadPageServiceModel { };
+ ReadPageWebModel readPageWebModel = new ReadPageWebModel
+ {
+ Posts = new List<ReadPostWebModel>
+ {
+ new ReadPostWebModel(),
+ new ReadPostWebModel(),
+ new ReadPostWebModel()
+ }
+ };
+
+ this.FeedServiceMock.Setup(p => p.GetUserPage(It.IsAny<GetPageServiceModel>())).Returns(Task.FromResult(readPageServiceModel));
+ this.MapperMock.Setup(p => p.Map<GetPageServiceModel>(It.IsAny<GetPageWebModel>())).Returns(getPageServiceModel);
+ this.MapperMock.Setup(p => p.Map<ReadPageWebModel>(It.IsAny<ReadPageServiceModel>())).Returns(readPageWebModel);
+
+ IActionResult result = await this.FeedController.GetUserPosts(null, getPageWebModel);
+
+ Assert.IsInstanceOf<OkObjectResult>(result);
+
+ OkObjectResult okObjectResult = result as OkObjectResult;
+ ReadPageWebModel resultModel = okObjectResult.Value as Models.Comment.ReadPageWebModel;
+
+ Assert.AreEqual(3, resultModel.Posts.Count);
+ }
+ #endregion
+ }
+}
diff --git a/src/DevHive.Tests/DevHive.Web.Tests/TechnologyController.Tests.cs b/src/DevHive.Tests/DevHive.Web.Tests/TechnologyController.Tests.cs
index d56a602..164bcbf 100644
--- a/src/DevHive.Tests/DevHive.Web.Tests/TechnologyController.Tests.cs
+++ b/src/DevHive.Tests/DevHive.Web.Tests/TechnologyController.Tests.cs
@@ -21,6 +21,7 @@ namespace DevHive.Web.Tests
private Mock<IMapper> MapperMock { get; set; }
private TechnologyController TechnologyController { get; set; }
+ #region SetUp
[SetUp]
public void SetUp()
{
@@ -28,6 +29,7 @@ namespace DevHive.Web.Tests
this.MapperMock = new Mock<IMapper>();
this.TechnologyController = new TechnologyController(this.TechnologyServiceMock.Object, this.MapperMock.Object);
}
+ #endregion
#region Create
[Test]
diff --git a/src/DevHive.Web/Configurations/Mapping/FeedMappings.cs b/src/DevHive.Web/Configurations/Mapping/FeedMappings.cs
index 159582d..0909f6d 100644
--- a/src/DevHive.Web/Configurations/Mapping/FeedMappings.cs
+++ b/src/DevHive.Web/Configurations/Mapping/FeedMappings.cs
@@ -1,6 +1,6 @@
using AutoMapper;
using DevHive.Services.Models;
-using DevHive.Web.Controllers;
+using DevHive.Web.Models.Comment;
using DevHive.Web.Models.Feed;
namespace DevHive.Web.Configurations.Mapping
diff --git a/src/DevHive.Web/Controllers/FeedController.cs b/src/DevHive.Web/Controllers/FeedController.cs
index 2f14cf3..abca3e4 100644
--- a/src/DevHive.Web/Controllers/FeedController.cs
+++ b/src/DevHive.Web/Controllers/FeedController.cs
@@ -3,6 +3,7 @@ using System.Threading.Tasks;
using AutoMapper;
using DevHive.Services.Interfaces;
using DevHive.Services.Models;
+using DevHive.Web.Models.Comment;
using DevHive.Web.Models.Feed;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
diff --git a/src/DevHive.Web/Models/Feed/ReadPageWebModel.cs b/src/DevHive.Web/Models/Feed/ReadPageWebModel.cs
index 839aaa6..f429313 100644
--- a/src/DevHive.Web/Models/Feed/ReadPageWebModel.cs
+++ b/src/DevHive.Web/Models/Feed/ReadPageWebModel.cs
@@ -1,7 +1,7 @@
using System.Collections.Generic;
using DevHive.Web.Models.Post;
-namespace DevHive.Web.Controllers
+namespace DevHive.Web.Models.Comment
{
public class ReadPageWebModel
{