protected ReportingClientBase(string appUri = null, string cdUri = null, string roatpUri = null) { apprenticeshipServiceUri = appUri; courceDirectoryUri = cdUri; roatpServiceUri = roatpUri; _assessmentOrgsApiClient = new AssessmentOrgsApiClient(apprenticeshipServiceUri); _inspectionOutcomeClient = new OfstedInspectionsClient(); }
public void TestWithoutLogger() { _processedWithLog = false; var inspectionOutcomesResponse = new OfstedInspectionsClient().GetOfstedInspectionOutcomes(); Assert.IsFalse(_processedWithLog); Assert.AreNotEqual(0, inspectionOutcomesResponse.InspectionOutcomes.Count); Assert.AreEqual(0, inspectionOutcomesResponse.InspectionOutcomeErrors.Count); }
public void TestWithLogger() { var logger = new LocalLogger(); _processedWithLog = false; var inspectionOutcomesResponse = new OfstedInspectionsClient(logger).GetOfstedInspectionOutcomes(); Assert.IsTrue(_processedWithLog); Assert.AreNotEqual(0, inspectionOutcomesResponse.InspectionOutcomes.Count); Assert.AreEqual(0, inspectionOutcomesResponse.InspectionOutcomeErrors.Count); }
public void ShouldReturnResultsWithoutErroring() { var mockAngleSharpService = new Mock <IAngleSharpService>(); mockAngleSharpService.Setup(x => x.GetLinks(It.IsAny <string>(), It.IsAny <string>(), It.IsAny <string>())) .Returns(new List <string> { "firstMatchingLink" }); var mockConfigurationSettings = new Mock <IConfigurationSettings>(); mockConfigurationSettings.Setup(x => x.InspectionSiteUrl).Returns("http://www.test.com/test2"); mockConfigurationSettings.Setup(x => x.LinkText).Returns("linkText Goes Here"); var mockGetInspectionsService = new Mock <IGetInspectionsService>(); var inspectionDetail = new InspectionOutcomesResponse { StatusCode = InspectionsStatusCode.Success, InspectionOutcomes = new List <InspectionOutcome> { new InspectionOutcome() }, InspectionOutcomeErrors = null }; var mockLogger = new Mock <ILogFunctions>(); var action = new Action <string>(message => { }); mockLogger.SetupGet(x => x.Info).Returns(action); mockLogger.SetupGet(x => x.Debug).Returns(action); mockGetInspectionsService.Setup(x => x.GetInspectionsDetail(It.IsAny <string>())).Returns(inspectionDetail); var ofstedInspectionsClient = new OfstedInspectionsClient(mockLogger.Object, mockAngleSharpService.Object, mockConfigurationSettings.Object, mockGetInspectionsService.Object); var res = ofstedInspectionsClient.GetOfstedInspectionOutcomes(); mockLogger.VerifyAll(); mockLogger.Verify(x => x.Info, Times.Exactly(2)); mockLogger.Verify(x => x.Debug, Times.Exactly(2)); Assert.AreEqual(InspectionsStatusCode.Success, res.StatusCode, $"The expected status code was success, but actual was [{res.StatusCode}]"); Assert.IsNotNull(res.InspectionOutcomes, $"The inspections should have some values, but was null"); Assert.AreEqual(1, res.InspectionOutcomes.Count, $"The number of inpections expected as 1, but actual was [{res.InspectionOutcomes.Count}]"); Assert.IsNull(res.InspectionOutcomeErrors, $"The Errorset expected was null, but actual was not null"); }
public void ShouldGiveNotProcessedErrorAndMessageWhenNoLinksFound() { var mockAngleSharpService = new Mock <IAngleSharpService>(); mockAngleSharpService.Setup(x => x.GetLinks(It.IsAny <string>(), It.IsAny <string>(), It.IsAny <string>())) .Returns(new List <string>()); var mockConfigurationSettings = new Mock <IConfigurationSettings>(); var mockLogger = new Mock <ILogFunctions>(); var mockGetInspectionsService = new Mock <GetInspectionsService>(mockLogger.Object, Mock.Of <IGetOfstedDetailsFromExcelPackageService>(), Mock.Of <IWebClientFactory>()); mockConfigurationSettings.Setup(x => x.InspectionSiteUrl).Returns("http://www.test.com/test2"); mockConfigurationSettings.Setup(x => x.LinkText).Returns("linkText Goes Here"); var errorMessageString = string.Empty; Exception errorException = null; var errorAction = new Action <string, Exception>((message, exception) => { errorMessageString = message; errorException = exception; }); mockLogger.SetupGet(x => x.Error).Returns(errorAction); var action = new Action <string>(message => { }); mockLogger.SetupGet(x => x.Info).Returns(action); mockLogger.SetupGet(x => x.Debug).Returns(action); var getOfstedInspections = new OfstedInspectionsClient( mockLogger.Object, mockAngleSharpService.Object, mockConfigurationSettings.Object, mockGetInspectionsService.Object ); Assert.Throws <NoLinksInPageException>(() => getOfstedInspections.GetOfstedInspectionOutcomes()); mockLogger.Verify(x => x.Info, Times.Exactly(1)); mockLogger.Verify(x => x.Debug, Times.Exactly(0)); Assert.IsTrue(errorMessageString.StartsWith("Could not locate any links in page ["), "Logged Error message does not contain expected words"); Assert.IsNotNull(errorException); Assert.IsTrue(errorException.Message.StartsWith("Could not locate any links in page ["), "Exception message does not contain expected words"); }
public void ShouldGiveNotProcessedErrorAndMessageWhenFirstLinkIsNotUrl() { var mockAngleSharpService = new Mock <IAngleSharpService>(); mockAngleSharpService.Setup(x => x.GetLinks(It.IsAny <string>(), It.IsAny <string>(), It.IsAny <string>())) .Returns(new List <string> { "firstMatchingLink" }); var mockConfigurationSettings = new Mock <IConfigurationSettings>(); mockConfigurationSettings.Setup(x => x.InspectionSiteUrl).Returns("badurl"); var mockLogger = new Mock <ILogFunctions>(); var mockGetInspectionsService = new Mock <GetInspectionsService>(mockLogger.Object, Mock.Of <IGetOfstedDetailsFromExcelPackageService>(), Mock.Of <IWebClientFactory>()); var errorMessageString = string.Empty; Exception errorException = null; var errorAction = new Action <string, Exception>((message, exception) => { errorMessageString = message; errorException = exception; }); mockLogger.SetupGet(x => x.Error).Returns(errorAction); var action = new Action <string>(message => { }); mockLogger.SetupGet(x => x.Info).Returns(action); mockLogger.SetupGet(x => x.Debug).Returns(action); var getOfstedInspections = new OfstedInspectionsClient( mockLogger.Object, mockAngleSharpService.Object, mockConfigurationSettings.Object, mockGetInspectionsService.Object ); Assert.Throws <InvalidLinkException>(() => getOfstedInspections.GetOfstedInspectionOutcomes()); mockLogger.Verify(x => x.Info, Times.Exactly(1)); mockLogger.Verify(x => x.Debug, Times.Exactly(1)); Assert.IsTrue(errorMessageString.StartsWith("Could not build a valid url from url ["), "Logged Error message does not contain expected words"); Assert.IsNotNull(errorException); Assert.IsTrue(errorException.Message.StartsWith("Could not build a valid url from url ["), "Exception message does not contain expected words"); }