Browse Source

调整UT位置

hjkl950217 5 years ago
parent
commit
190184e388
40 changed files with 17 additions and 2106 deletions
  1. 14 14
      Masuit.Tools.sln
  2. 0 171
      MigrationBackup/e4df0730/测试/Masuit.Tools.Test/Masuit.Tools.Test.csproj
  3. 0 162
      MigrationBackup/e4df0730/测试/Masuit.Tools.Test/NuGetUpgradeLog.html
  4. 0 4
      MigrationBackup/e4df0730/测试/Masuit.Tools.Test/packages.config
  5. 0 0
      Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Controllers/TestController.cs
  6. 1 1
      Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest.csproj
  7. 0 0
      Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest.xml
  8. 0 0
      Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Program.cs
  9. 0 0
      Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Properties/launchSettings.json
  10. 0 0
      Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Startup.cs
  11. 0 0
      Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/appsettings.Development.json
  12. 0 0
      Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/appsettings.json
  13. 0 0
      Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/wwwroot/TestFile.txt
  14. 2 1
      Test/Masuit.Tools.ExpressionMapperBenchmark/Masuit.Tools.ExpressionMapperBenchmark.csproj
  15. 0 0
      Test/Masuit.Tools.ExpressionMapperBenchmark/Program.cs
  16. 0 0
      Test/Masuit.Tools.ExpressionMapperBenchmark/TestClassA.cs
  17. 0 35
      Test/Masuit.Tools.Test2222222222/ChineseCalendarTest.cs
  18. 0 41
      Test/Masuit.Tools.Test2222222222/CompressTest.cs
  19. 0 38
      Test/Masuit.Tools.Test2222222222/ExtensionMethodsTest.cs
  20. 0 25
      Test/Masuit.Tools.Test2222222222/HtmlToolsTest.cs
  21. 0 36
      Test/Masuit.Tools.Test2222222222/LinqExtensionTest.cs
  22. 0 170
      Test/Masuit.Tools.Test2222222222/Masuit.Tools.Test.csproj
  23. 0 84
      Test/Masuit.Tools.Test2222222222/Mvc/BaseTests.cs
  24. 0 82
      Test/Masuit.Tools.Test2222222222/Mvc/MimeMapperTests.cs
  25. 0 35
      Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockHttpFilesCollection.cs
  26. 0 40
      Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockHttpPostedFileBase.cs
  27. 0 61
      Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockHttpRequest.cs
  28. 0 84
      Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockHttpResponse.cs
  29. 0 36
      Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockHttpSession.cs
  30. 0 8
      Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockRequestContext.cs
  31. 0 46
      Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockResumeFileResult.cs
  32. 0 505
      Test/Masuit.Tools.Test2222222222/Mvc/ResumeFileResultTests.cs
  33. 0 60
      Test/Masuit.Tools.Test2222222222/NumberFormaterTest.cs
  34. 0 19
      Test/Masuit.Tools.Test2222222222/Properties/AssemblyInfo.cs
  35. 0 27
      Test/Masuit.Tools.Test2222222222/RSATest.cs
  36. 0 52
      Test/Masuit.Tools.Test2222222222/Reflection/ClassHelperTest.cs
  37. 0 101
      Test/Masuit.Tools.Test2222222222/Resources/download-test-file.txt
  38. 0 101
      Test/Masuit.Tools.Test2222222222/Resources/download-test-file2.txt
  39. 0 44
      Test/Masuit.Tools.Test2222222222/TemplateTest.cs
  40. 0 23
      Test/Masuit.Tools.Test2222222222/app.config

+ 14 - 14
Masuit.Tools.sln

@@ -11,10 +11,6 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "测试", "测试", "{E0B8FB
 EndProject
 Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "NetCoreTest", "NetCoreTest\NetCoreTest.csproj", "{ABEC3F65-6556-44FD-BECE-33F7927FB3AE}"
 EndProject
-Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Masuit.Tools.AspNetCore.ResumeFileResults.WebTest", "Masuit.Tools.AspNetCore.ResumeFileResults.WebTest\Masuit.Tools.AspNetCore.ResumeFileResults.WebTest.csproj", "{49E16577-01CD-4104-B73E-449B2960D956}"
-EndProject
-Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Masuit.Tools.ExpressionMapperBenchmark", "Masuit.Tools.ExpressionMapperBenchmark\Masuit.Tools.ExpressionMapperBenchmark.csproj", "{1D51DC49-6626-41AF-B1B5-085C83307FF2}"
-EndProject
 Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Masuit.Tools.NoSQL.MongoDBClient", "Masuit.Tools.NoSQL.MongoDBClient\Masuit.Tools.NoSQL.MongoDBClient.csproj", "{2C4FF8E9-2662-4618-ABA4-BA55AA5EA9AB}"
 EndProject
 Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Masuit.Tools.Abstractions", "Masuit.Tools.Abstractions\Masuit.Tools.Abstractions.csproj", "{74E7C0A2-499D-408F-A2E4-08878700C2DE}"
@@ -30,6 +26,10 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution
 		SDKPulishNuget.targets = SDKPulishNuget.targets
 	EndProjectSection
 EndProject
+Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Masuit.Tools.AspNetCore.ResumeFileResults.WebTest", "Test\Masuit.Tools.AspNetCore.ResumeFileResults.WebTest\Masuit.Tools.AspNetCore.ResumeFileResults.WebTest.csproj", "{99185F12-DFAD-4DB8-A2C4-C7E9700C0A31}"
+EndProject
+Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Masuit.Tools.ExpressionMapperBenchmark", "Test\Masuit.Tools.ExpressionMapperBenchmark\Masuit.Tools.ExpressionMapperBenchmark.csproj", "{B5657BBC-E50E-4CAD-B78B-6E2CCB139F98}"
+EndProject
 Global
 	GlobalSection(SolutionConfigurationPlatforms) = preSolution
 		Debug|Any CPU = Debug|Any CPU
@@ -48,14 +48,6 @@ Global
 		{ABEC3F65-6556-44FD-BECE-33F7927FB3AE}.Debug|Any CPU.Build.0 = Debug|Any CPU
 		{ABEC3F65-6556-44FD-BECE-33F7927FB3AE}.Release|Any CPU.ActiveCfg = Release|Any CPU
 		{ABEC3F65-6556-44FD-BECE-33F7927FB3AE}.Release|Any CPU.Build.0 = Release|Any CPU
-		{49E16577-01CD-4104-B73E-449B2960D956}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
-		{49E16577-01CD-4104-B73E-449B2960D956}.Debug|Any CPU.Build.0 = Debug|Any CPU
-		{49E16577-01CD-4104-B73E-449B2960D956}.Release|Any CPU.ActiveCfg = Release|Any CPU
-		{49E16577-01CD-4104-B73E-449B2960D956}.Release|Any CPU.Build.0 = Release|Any CPU
-		{1D51DC49-6626-41AF-B1B5-085C83307FF2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
-		{1D51DC49-6626-41AF-B1B5-085C83307FF2}.Debug|Any CPU.Build.0 = Debug|Any CPU
-		{1D51DC49-6626-41AF-B1B5-085C83307FF2}.Release|Any CPU.ActiveCfg = Release|Any CPU
-		{1D51DC49-6626-41AF-B1B5-085C83307FF2}.Release|Any CPU.Build.0 = Release|Any CPU
 		{2C4FF8E9-2662-4618-ABA4-BA55AA5EA9AB}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
 		{2C4FF8E9-2662-4618-ABA4-BA55AA5EA9AB}.Debug|Any CPU.Build.0 = Debug|Any CPU
 		{2C4FF8E9-2662-4618-ABA4-BA55AA5EA9AB}.Release|Any CPU.ActiveCfg = Release|Any CPU
@@ -76,16 +68,24 @@ Global
 		{92F3DA7E-669A-4A6D-AC8B-018CABCBEFB9}.Debug|Any CPU.Build.0 = Debug|Any CPU
 		{92F3DA7E-669A-4A6D-AC8B-018CABCBEFB9}.Release|Any CPU.ActiveCfg = Release|Any CPU
 		{92F3DA7E-669A-4A6D-AC8B-018CABCBEFB9}.Release|Any CPU.Build.0 = Release|Any CPU
+		{99185F12-DFAD-4DB8-A2C4-C7E9700C0A31}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+		{99185F12-DFAD-4DB8-A2C4-C7E9700C0A31}.Debug|Any CPU.Build.0 = Debug|Any CPU
+		{99185F12-DFAD-4DB8-A2C4-C7E9700C0A31}.Release|Any CPU.ActiveCfg = Release|Any CPU
+		{99185F12-DFAD-4DB8-A2C4-C7E9700C0A31}.Release|Any CPU.Build.0 = Release|Any CPU
+		{B5657BBC-E50E-4CAD-B78B-6E2CCB139F98}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+		{B5657BBC-E50E-4CAD-B78B-6E2CCB139F98}.Debug|Any CPU.Build.0 = Debug|Any CPU
+		{B5657BBC-E50E-4CAD-B78B-6E2CCB139F98}.Release|Any CPU.ActiveCfg = Release|Any CPU
+		{B5657BBC-E50E-4CAD-B78B-6E2CCB139F98}.Release|Any CPU.Build.0 = Release|Any CPU
 	EndGlobalSection
 	GlobalSection(SolutionProperties) = preSolution
 		HideSolutionNode = FALSE
 	EndGlobalSection
 	GlobalSection(NestedProjects) = preSolution
-		{49E16577-01CD-4104-B73E-449B2960D956} = {E0B8FBD1-A28A-4420-9DE2-6BD06035CBAC}
-		{1D51DC49-6626-41AF-B1B5-085C83307FF2} = {E0B8FBD1-A28A-4420-9DE2-6BD06035CBAC}
 		{B8BFA5B2-20BF-4D9C-A9F3-5E33EC6A0B20} = {E0B8FBD1-A28A-4420-9DE2-6BD06035CBAC}
 		{61430D45-3808-49B5-BDF3-4536DA399DD4} = {E0B8FBD1-A28A-4420-9DE2-6BD06035CBAC}
 		{92F3DA7E-669A-4A6D-AC8B-018CABCBEFB9} = {E0B8FBD1-A28A-4420-9DE2-6BD06035CBAC}
+		{99185F12-DFAD-4DB8-A2C4-C7E9700C0A31} = {E0B8FBD1-A28A-4420-9DE2-6BD06035CBAC}
+		{B5657BBC-E50E-4CAD-B78B-6E2CCB139F98} = {E0B8FBD1-A28A-4420-9DE2-6BD06035CBAC}
 	EndGlobalSection
 	GlobalSection(ExtensibilityGlobals) = postSolution
 		SolutionGuid = {B57FDA8F-95CF-478B-A0A8-7FF0F01CCFAB}

+ 0 - 171
MigrationBackup/e4df0730/测试/Masuit.Tools.Test/Masuit.Tools.Test.csproj

@@ -1,171 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project ToolsVersion="15.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
-  <Import Project="..\..\packages\xunit.core.2.4.1\build\xunit.core.props" Condition="Exists('..\..\packages\xunit.core.2.4.1\build\xunit.core.props')" />
-  <Import Project="..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.props" Condition="Exists('..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.props')" />
-  <Import Project="..\packages\NUnit.3.12.0\build\NUnit.props" Condition="Exists('..\packages\NUnit.3.12.0\build\NUnit.props')" />
-  <Import Project="..\packages\xunit.core.2.4.1\build\xunit.core.props" Condition="Exists('..\packages\xunit.core.2.4.1\build\xunit.core.props')" />
-  <Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
-  <PropertyGroup>
-    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
-    <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
-    <ProjectGuid>{174474CB-0C9A-4C99-B461-1A2158F00A98}</ProjectGuid>
-    <OutputType>Library</OutputType>
-    <AppDesignerFolder>Properties</AppDesignerFolder>
-    <RootNamespace>Masuit.Tools.UnitTest</RootNamespace>
-    <AssemblyName>Masuit.Tools.UnitTest</AssemblyName>
-    <TargetFrameworkVersion>v4.6.1</TargetFrameworkVersion>
-    <FileAlignment>512</FileAlignment>
-    <ProjectTypeGuids>{3AC096D0-A1C2-E12C-1390-A8335801FDAB};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}</ProjectTypeGuids>
-    <VisualStudioVersion Condition="'$(VisualStudioVersion)' == ''">15.0</VisualStudioVersion>
-    <VSToolsPath Condition="'$(VSToolsPath)' == ''">$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)</VSToolsPath>
-    <ReferencePath>$(ProgramFiles)\Common Files\microsoft shared\VSTT\$(VisualStudioVersion)\UITestExtensionPackages</ReferencePath>
-    <IsCodedUITest>False</IsCodedUITest>
-    <TestProjectType>UnitTest</TestProjectType>
-    <NuGetPackageImportStamp>
-    </NuGetPackageImportStamp>
-  </PropertyGroup>
-  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
-    <DebugSymbols>true</DebugSymbols>
-    <DebugType>full</DebugType>
-    <Optimize>false</Optimize>
-    <OutputPath>bin\Debug\</OutputPath>
-    <DefineConstants>DEBUG;TRACE</DefineConstants>
-    <ErrorReport>prompt</ErrorReport>
-    <WarningLevel>4</WarningLevel>
-    <LangVersion>8.0</LangVersion>
-  </PropertyGroup>
-  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
-    <DebugType>pdbonly</DebugType>
-    <Optimize>true</Optimize>
-    <OutputPath>bin\Release\</OutputPath>
-    <DefineConstants>TRACE</DefineConstants>
-    <ErrorReport>prompt</ErrorReport>
-    <WarningLevel>4</WarningLevel>
-    <LangVersion>8.0</LangVersion>
-  </PropertyGroup>
-  <ItemGroup>
-    <Reference Include="Microsoft.CSharp" />
-    <Reference Include="Microsoft.VisualStudio.TestPlatform.TestFramework, Version=14.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a, processorArchitecture=MSIL">
-      <HintPath>..\packages\MSTest.TestFramework.2.1.2\lib\net45\Microsoft.VisualStudio.TestPlatform.TestFramework.dll</HintPath>
-    </Reference>
-    <Reference Include="Microsoft.VisualStudio.TestPlatform.TestFramework.Extensions, Version=14.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a, processorArchitecture=MSIL">
-      <HintPath>..\packages\MSTest.TestFramework.2.1.2\lib\net45\Microsoft.VisualStudio.TestPlatform.TestFramework.Extensions.dll</HintPath>
-    </Reference>
-    <Reference Include="Microsoft.Web.Infrastructure, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.Web.Infrastructure.1.0.0.0\lib\net40\Microsoft.Web.Infrastructure.dll</HintPath>
-    </Reference>
-    <Reference Include="Moq, Version=4.14.0.0, Culture=neutral, PublicKeyToken=69f491c39445e920, processorArchitecture=MSIL">
-      <HintPath>..\packages\Moq.4.14.5\lib\net45\Moq.dll</HintPath>
-    </Reference>
-    <Reference Include="nunit.framework, Version=3.12.0.0, Culture=neutral, PublicKeyToken=2638cd05610744eb, processorArchitecture=MSIL">
-      <HintPath>..\packages\NUnit.3.12.0\lib\net45\nunit.framework.dll</HintPath>
-    </Reference>
-    <Reference Include="System" />
-    <Reference Include="System.Configuration" />
-    <Reference Include="System.Core" />
-    <Reference Include="System.Net.Http" />
-    <Reference Include="System.Numerics" />
-    <Reference Include="System.Runtime.CompilerServices.Unsafe, Version=4.0.6.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a, processorArchitecture=MSIL">
-      <HintPath>..\packages\System.Runtime.CompilerServices.Unsafe.4.7.1\lib\net461\System.Runtime.CompilerServices.Unsafe.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Threading.Tasks.Extensions, Version=4.2.0.1, Culture=neutral, PublicKeyToken=cc7b13ffcd2ddd51, processorArchitecture=MSIL">
-      <HintPath>..\packages\System.Threading.Tasks.Extensions.4.5.4\lib\net461\System.Threading.Tasks.Extensions.dll</HintPath>
-    </Reference>
-    <Reference Include="System.ValueTuple, Version=4.0.3.0, Culture=neutral, PublicKeyToken=cc7b13ffcd2ddd51, processorArchitecture=MSIL">
-      <HintPath>..\packages\System.ValueTuple.4.5.0\lib\net461\System.ValueTuple.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Web" />
-    <Reference Include="System.Web.Helpers, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.WebPages.3.2.7\lib\net45\System.Web.Helpers.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Web.Mvc, Version=5.2.7.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.Mvc.5.2.7\lib\net45\System.Web.Mvc.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Web.Razor, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.Razor.3.2.7\lib\net45\System.Web.Razor.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Web.WebPages, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.WebPages.3.2.7\lib\net45\System.Web.WebPages.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Web.WebPages.Deployment, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.WebPages.3.2.7\lib\net45\System.Web.WebPages.Deployment.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Web.WebPages.Razor, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.WebPages.3.2.7\lib\net45\System.Web.WebPages.Razor.dll</HintPath>
-    </Reference>
-    <Reference Include="xunit.abstractions, Version=2.0.0.0, Culture=neutral, PublicKeyToken=8d05b1bb7a6fdb6c, processorArchitecture=MSIL">
-      <HintPath>..\packages\xunit.abstractions.2.0.3\lib\net35\xunit.abstractions.dll</HintPath>
-    </Reference>
-    <Reference Include="xunit.assert, Version=2.4.1.0, Culture=neutral, PublicKeyToken=8d05b1bb7a6fdb6c, processorArchitecture=MSIL">
-      <HintPath>..\..\packages\xunit.assert.2.4.1\lib\netstandard1.1\xunit.assert.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="xunit.core, Version=2.4.1.0, Culture=neutral, PublicKeyToken=8d05b1bb7a6fdb6c, processorArchitecture=MSIL">
-      <HintPath>..\..\packages\xunit.extensibility.core.2.4.1\lib\net452\xunit.core.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="xunit.execution.desktop, Version=2.4.1.0, Culture=neutral, PublicKeyToken=8d05b1bb7a6fdb6c, processorArchitecture=MSIL">
-      <HintPath>..\..\packages\xunit.extensibility.execution.2.4.1\lib\net452\xunit.execution.desktop.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-  </ItemGroup>
-  <ItemGroup>
-    <Compile Include="ChineseCalendarTest.cs" />
-    <Compile Include="Reflection\ClassHelperTest.cs" />
-    <Compile Include="CompressTest.cs" />
-    <Compile Include="ExtensionMethodsTest.cs" />
-    <Compile Include="HtmlToolsTest.cs" />
-    <Compile Include="LinqExtensionTest.cs" />
-    <Compile Include="Mvc\BaseTests.cs" />
-    <Compile Include="Mvc\Mocks\MockHttpFilesCollection.cs" />
-    <Compile Include="Mvc\Mocks\MockHttpPostedFileBase.cs" />
-    <Compile Include="Mvc\Mocks\MockHttpRequest.cs" />
-    <Compile Include="Mvc\Mocks\MockHttpResponse.cs" />
-    <Compile Include="Mvc\Mocks\MockHttpSession.cs" />
-    <Compile Include="Mvc\Mocks\MockRequestContext.cs" />
-    <Compile Include="Mvc\Mocks\MockResumeFileResult.cs" />
-    <Compile Include="Mvc\ResumeFileResultTests.cs" />
-    <Compile Include="NumberFormaterTest.cs" />
-    <Compile Include="Properties\AssemblyInfo.cs" />
-    <Compile Include="RSATest.cs" />
-    <Compile Include="TemplateTest.cs" />
-  </ItemGroup>
-  <ItemGroup>
-    <None Include="app.config" />
-    <None Include="packages.config" />
-  </ItemGroup>
-  <ItemGroup>
-    <ProjectReference Include="..\..\Masuit.Tools\Masuit.Tools.csproj">
-      <Project>{275d5a0d-c49c-497e-a4b5-f40285c2495f}</Project>
-      <Name>Masuit.Tools</Name>
-    </ProjectReference>
-  </ItemGroup>
-  <ItemGroup>
-    <Analyzer Include="..\packages\xunit.analyzers.0.10.0\analyzers\dotnet\cs\xunit.analyzers.dll" />
-  </ItemGroup>
-  <ItemGroup>
-    <Content Include="Resources\download-test-file.txt">
-      <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
-    </Content>
-    <Content Include="Resources\download-test-file2.txt">
-      <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
-    </Content>
-  </ItemGroup>
-  <Import Project="$(VSToolsPath)\TeamTest\Microsoft.TestTools.targets" Condition="Exists('$(VSToolsPath)\TeamTest\Microsoft.TestTools.targets')" />
-  <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
-  <Target Name="EnsureNuGetPackageBuildImports" BeforeTargets="PrepareForBuild">
-    <PropertyGroup>
-      <ErrorText>这台计算机上缺少此项目引用的 NuGet 程序包。使用“NuGet 程序包还原”可下载这些程序包。有关更多信息,请参见 http://go.microsoft.com/fwlink/?LinkID=322105。缺少的文件是 {0}。</ErrorText>
-    </PropertyGroup>
-    <Error Condition="!Exists('..\packages\xunit.core.2.4.1\build\xunit.core.props')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\xunit.core.2.4.1\build\xunit.core.props'))" />
-    <Error Condition="!Exists('..\packages\xunit.core.2.4.1\build\xunit.core.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\xunit.core.2.4.1\build\xunit.core.targets'))" />
-    <Error Condition="!Exists('..\packages\NUnit.3.12.0\build\NUnit.props')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\NUnit.3.12.0\build\NUnit.props'))" />
-    <Error Condition="!Exists('..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.props')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.props'))" />
-    <Error Condition="!Exists('..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.targets'))" />
-    <Error Condition="!Exists('..\..\packages\xunit.core.2.4.1\build\xunit.core.props')" Text="$([System.String]::Format('$(ErrorText)', '..\..\packages\xunit.core.2.4.1\build\xunit.core.props'))" />
-    <Error Condition="!Exists('..\..\packages\xunit.core.2.4.1\build\xunit.core.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\..\packages\xunit.core.2.4.1\build\xunit.core.targets'))" />
-  </Target>
-  <Import Project="..\packages\xunit.core.2.4.1\build\xunit.core.targets" Condition="Exists('..\packages\xunit.core.2.4.1\build\xunit.core.targets')" />
-  <Import Project="..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.targets" Condition="Exists('..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.targets')" />
-  <Import Project="..\..\packages\xunit.core.2.4.1\build\xunit.core.targets" Condition="Exists('..\..\packages\xunit.core.2.4.1\build\xunit.core.targets')" />
-</Project>

+ 0 - 162
MigrationBackup/e4df0730/测试/Masuit.Tools.Test/NuGetUpgradeLog.html

@@ -1,162 +0,0 @@
-<!DOCTYPE html>
-<!-- saved from url=(0014)about:internet -->
-
-    <html xmlns:msxsl="urn:schemas-microsoft-com:xslt"><head><meta content="en-us" http-equiv="Content-Language" /><meta content="text/html; charset=utf-16" http-equiv="Content-Type" /><title _locID="NuGetUpgradeReportTitle">
-          NuGetMigrationLog
-        </title><style>
-            
-                    /* Body style, for the entire document */
-                    body
-                    {
-                        background: #F3F3F4;
-                        color: #1E1E1F;
-                        font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
-                        font-size: 12pt;
-                        padding: 0;
-                        margin: 0;
-                    }
-
-                    /* Header1 style, used for the main title */
-                    h1
-                    {
-                        padding: 10px 0px 10px 10px;
-                        font-size: 21pt;
-                        background-color: #E2E2E2;
-                        border-bottom: 1px #C1C1C2 solid; 
-                        color: #201F20;
-                        margin: 0;
-                        font-weight: normal;
-                    }
-
-                    /* Header2 style, used for "Overview" and other sections */
-                    h2
-                    {
-                        font-size: 18pt;
-                        font-weight: normal;
-                        padding: 15px 0 5px 0;
-                        margin: 0;
-                    }
-
-                    /* Header3 style, used for sub-sections, such as project name */
-                    h3
-                    {
-                        font-weight: normal;
-                        font-size: 15pt;
-                        margin: 0;
-                        padding: 15px 0 5px 0;
-                        background-color: transparent;
-                    }
-
-                    .info-text
-                    {
-                        margin: 0px 0 0.75em 0;
-                    }
-
-                    /* Color all hyperlinks one color */
-                    a
-                    {
-                        color: #1382CE;
-                    }
-
-                    /* Table styles */ 
-                    table
-                    {
-                        border-spacing: 0 0;
-                        border-collapse: collapse;
-                        font-size: 11pt;
-                    }
-
-                    table th
-                    {
-                        background: #E7E7E8;
-                        text-align: left;
-                        text-decoration: none;
-                        font-weight: normal;
-                        padding: 3px 6px 3px 6px;
-                    }
-
-                    table td
-                    {
-                        vertical-align: top;
-                        padding: 3px 6px 5px 5px;
-                        margin: 0px;
-                        border: 1px solid #E7E7E8;
-                        background: #F7F7F8;
-                    }
-
-                    /* Local link is a style for hyperlinks that link to file:/// content, there are lots so color them as 'normal' text until the user mouse overs */
-                    .localLink
-                    {
-                        color: #1E1E1F;
-                        background: #EEEEED;
-                        text-decoration: none;
-                    }
-
-                    .localLink:hover
-                    {
-                        color: #1382CE;
-                        background: #FFFF99;
-                        text-decoration: none;
-                    }
-
-                    .issueCell
-                    {
-                        width: 100%;
-                    }
-
-                    .packageIssue
-                    {
-                        margin-left: 25px;
-                    }
-
-                    /* Padding around the content after the h1 */ 
-                    #content 
-                    {
-	                    padding: 0px 20px 20px 20px; 
-                    }
-
-                    .issues table
-                    {
-                        width: 97%;
-                    }
-
-                    /* All Icons */
-                    .IconSuccessEncoded, .IconInfoEncoded, .IconWarningEncoded, .IconErrorEncoded
-                    {
-                        min-width:18px;
-                        min-height:18px; 
-                        background-repeat:no-repeat;
-                        background-position:center;
-                    }
-
-                    .IconSuccessEncoded
-                    {
-                        background-image: url();
-                    }
-
-                    .IconInfoEncoded
-                    {
-                        background-image: url();
-                    }
-
-                    .IconWarningEncoded
-                    {
-                        background-image: url();
-                    }
-
-                    .IconErrorEncoded
-                    {
-                        background-image: url();
-                    }
-                
-          </style></head><body><h1>
-          NuGet Migration Report - 测试\Masuit.Tools.Test</h1><div id="content"><h2 _locID="OverviewTitle">Overview</h2><div class="info-text">Migration to PackageReference was completed successfully. Please build and run your solution to verify that all packages are available.</div><div class="info-text">
-            If you run into any problems, have feedback, questions, or concerns, please
-            <a href="https://github.com/NuGet/Home/issues/">file an issue on the NuGet GitHub repository.</a></div><div class="info-text">
-            Changed files and this report have been backed up here:
-            <a href="E:\资料和文档等\学习相关\工作区\Masuit.Tools-Main\MigrationBackup\e4df0730\测试\Masuit.Tools.Test">E:\资料和文档等\学习相关\工作区\Masuit.Tools-Main\MigrationBackup\e4df0730\测试\Masuit.Tools.Test</a></div><div class="info-text"><a href="https://aka.ms/nuget-pc2pr-migrator-rollback">Help me rollback to packages.config</a></div><h2 _locID="PackagesTitle">Packages processed</h2><h3 _locID="IncludePackagesTitle">Top-level dependencies:</h3><div class="issues"><table><tr><th class="issueCell">Package Id</th><th>Version</th></tr><tr><td class="issueCell"><span>Castle.Core</span></td><td><span>
-                v4.4.1</span></td></tr></table></div><p /><h3 _locID="IncludePackagesTitle">Transitive dependencies:</h3><div class="issues"><table><tr><th class="issueCell">Package Id</th><th>Version</th></tr><tr><td class="issueCell">
-                No transitive dependencies found.
-              </td><td /></tr></table></div><h2 _locID="IssuesTitle">Package compatibility issues</h2><div class="issues"><table><tr><th /><th class="issueCell" _locID="DescriptionTableHeader">Description</th></tr><tr><td class="IconInfoEncoded" /><td class="issueCell">
-                No issues were found.
-              </td></tr></table></div></div></body></html>

+ 0 - 4
MigrationBackup/e4df0730/测试/Masuit.Tools.Test/packages.config

@@ -1,4 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<packages>
-  <package id="Castle.Core" version="4.4.1" targetFramework="net461" />
-</packages>

+ 0 - 0
Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Controllers/TestController.cs → Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Controllers/TestController.cs


+ 1 - 1
Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest.csproj → Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest.csproj

@@ -28,7 +28,7 @@
   </ItemGroup>
 
   <ItemGroup>
-    <ProjectReference Include="..\Masuit.Tools.Core\Masuit.Tools.Core.csproj" />
+    <ProjectReference Include="..\..\Masuit.Tools.Core\Masuit.Tools.Core.csproj" />
   </ItemGroup>
 
   <ItemGroup>

+ 0 - 0
Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest.xml → Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest.xml


+ 0 - 0
Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Program.cs → Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Program.cs


+ 0 - 0
Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Properties/launchSettings.json → Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Properties/launchSettings.json


+ 0 - 0
Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Startup.cs → Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/Startup.cs


+ 0 - 0
Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/appsettings.Development.json → Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/appsettings.Development.json


+ 0 - 0
Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/appsettings.json → Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/appsettings.json


+ 0 - 0
Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/wwwroot/TestFile.txt → Test/Masuit.Tools.AspNetCore.ResumeFileResults.WebTest/wwwroot/TestFile.txt


+ 2 - 1
Masuit.Tools.ExpressionMapperBenchmark/Masuit.Tools.ExpressionMapperBenchmark.csproj → Test/Masuit.Tools.ExpressionMapperBenchmark/Masuit.Tools.ExpressionMapperBenchmark.csproj

@@ -18,8 +18,9 @@
     <PackageReference Include="AutoMapper" Version="10.0.0" />
   </ItemGroup>
 
+
   <ItemGroup>
-    <ProjectReference Include="..\Masuit.Tools.Core\Masuit.Tools.Core.csproj" />
+    <ProjectReference Include="..\..\Masuit.Tools.Core\Masuit.Tools.Core.csproj" />
   </ItemGroup>
 
 </Project>

+ 0 - 0
Masuit.Tools.ExpressionMapperBenchmark/Program.cs → Test/Masuit.Tools.ExpressionMapperBenchmark/Program.cs


+ 0 - 0
Masuit.Tools.ExpressionMapperBenchmark/TestClassA.cs → Test/Masuit.Tools.ExpressionMapperBenchmark/TestClassA.cs


+ 0 - 35
Test/Masuit.Tools.Test2222222222/ChineseCalendarTest.cs

@@ -1,35 +0,0 @@
-using Masuit.Tools.DateTimeExt;
-using System;
-using Xunit;
-
-namespace Masuit.Tools.Test
-{
-    public class ChineseCalendarTest
-    {
-        [Fact]
-        public void GetChineseDateString_ReturnChineseDateString()
-        {
-            var cc = new ChineseCalendar(DateTime.Parse("2018-11-27"));
-            string actual = cc.ChineseDateString;
-            Assert.Equal("二零一八年十月二十", actual);
-        }
-
-        [Theory, InlineData("2018-11-27"), InlineData("2019-02-02")]
-        public void JudgeWorkDay_ReturnTrue(string date)
-        {
-            ChineseCalendar.CustomWorkDays.Add(DateTime.Parse("2019-02-02"));
-            var cc = new ChineseCalendar(DateTime.Parse(date));
-            var actual = cc.IsWorkDay;
-            Assert.True(actual);
-        }
-
-        [Fact]
-        public void JudgeHoliday_ReturnTrue()
-        {
-            ChineseCalendar.CustomHolidays.Add(DateTime.Parse("2019-2-6"), "春节");
-            var cc = new ChineseCalendar(DateTime.Parse("2019-2-6"));
-            var actual = cc.IsHoliday;
-            Assert.True(actual);
-        }
-    }
-}

+ 0 - 41
Test/Masuit.Tools.Test2222222222/CompressTest.cs

@@ -1,41 +0,0 @@
-using Masuit.Tools.Files;
-using System;
-using System.Collections.Generic;
-using System.Diagnostics;
-using System.IO;
-using Xunit;
-
-namespace Masuit.Tools.Test
-{
-    public class CompressTest
-    {
-        [Fact]
-        public void Can_CompressFiles_ReturnStream()
-        {
-            var ms = SevenZipCompressor.ZipStream(new List<string>()
-            {
-                //AppContext.BaseDirectory,
-                "http://ww3.sinaimg.cn/large/87c01ec7gy1fsq6rywto2j20je0d3td0.jpg",
-                "http://192.168.16.150:3000string",
-            });
-            Assert.True(ms.Length > 0);
-        }
-
-        [Fact]
-        public void Can_CompressToFile()
-        {
-            string zip = Path.Combine(Environment.GetEnvironmentVariable("temp"), Stopwatch.GetTimestamp() + ".rar");
-            SevenZipCompressor.Zip(new List<string>()
-            {
-                AppContext.BaseDirectory,
-                "http://ww3.sinaimg.cn/large/87c01ec7gy1fsq6rywto2j20je0d3td0.jpg",
-                "http://192.168.16.150:3000string",
-            }, zip);
-            using (FileStream stream = File.OpenRead(zip))
-            {
-                Assert.True(stream.Length > 0);
-            }
-        }
-
-    }
-}

+ 0 - 38
Test/Masuit.Tools.Test2222222222/ExtensionMethodsTest.cs

@@ -1,38 +0,0 @@
-using Microsoft.VisualStudio.TestTools.UnitTesting;
-using Xunit;
-using Assert = Microsoft.VisualStudio.TestTools.UnitTesting.Assert;
-
-namespace Masuit.Tools.Test
-{
-    [TestClass]
-    public class ExtensionMethodsTest
-    {
-        [TestMethod]
-        public void MatchUrl_True()
-        {
-            bool expect = "https://git.lug.us-tc.edu.cn/masuit/soft".MatchUrl();
-            Assert.AreEqual(true, expect);
-        }
-
-        [TestMethod]
-        public void MatchEmail()
-        {
-            var (expect, match) = "[email protected]".MatchEmail();
-            Assert.AreEqual(true, expect);
-        }
-        [TestMethod]
-        public void MatchIdentifyCard_False()
-        {
-            bool expect = "513901199509120610".MatchIdentifyCard();
-            Assert.AreEqual(false, expect);
-        }
-
-        [Theory]
-        [InlineData("16666666666")]
-        [InlineData("19999999999")]
-        public void Can_MatchPhoneNumber_(string phone)
-        {
-            Xunit.Assert.True(phone.MatchPhoneNumber());
-        }
-    }
-}

+ 0 - 25
Test/Masuit.Tools.Test2222222222/HtmlToolsTest.cs

@@ -1,25 +0,0 @@
-using Masuit.Tools.Html;
-using Xunit;
-
-namespace Masuit.Tools.Test
-{
-    public class HtmlToolsTest
-    {
-        [Theory]
-        [InlineData("<p><img src=\"https://ww1.sinaimg.cn/large/007iUjdily1fxefem7juyj30ld037q35\"/></p><p><img src=\"https://ww1.sinaimg.cn/large/007iUjdily1fxeffei83dj30l90nbgr8\"/></p><p><img src=\"https://ww1.sinaimg.cn/large/007iUjdily1fxeffz9u1kj30lc0n90y1\"/></p><p><img src=\"https://ww1.sinaimg.cn/large/007iUjdily1fxefgh6xxoj30lc09aq4q\"/></p>")]
-        [InlineData("<p><img title=\"title\" src=\"https://ww1.sinaimg.cn/large/007iUjdily1fxefem7juyj30ld037q35\"/></p><p><img title=\"title\" src=\"https://ww1.sinaimg.cn/large/007iUjdily1fxeffei83dj30l90nbgr8\"/></p><p><img src=\"https://ww1.sinaimg.cn/large/007iUjdily1fxeffz9u1kj30lc0n90y1\"/></p><p><img title=\"title\" src=\"https://ww1.sinaimg.cn/large/007iUjdily1fxefgh6xxoj30lc09aq4q\"/></p>")]
-        public void MatchRandomImgSrc_NormalHtml_ReturnAImgUrl(string html)
-        {
-            string src = html.MatchRandomImgSrc();
-            Assert.True(src.StartsWith("http"));
-        }
-
-        [Fact]
-        public void MatchRandomImgSrc_NoImgHtml_ReturnNull()
-        {
-            string html = "<p>如果你是通过某宝、或是其他论坛等渠道,通过任何付费的方式获取到本资源,请直接退款并在相应的平台举报,如果是论坛的,请将本页链接分享到你购买源的评论区,告诫他人谨防上当,或者直接将本页链接转发分享给有需要的人,感谢您的支持和监督。</p>";
-            string src = html.MatchRandomImgSrc();
-            Assert.True(string.IsNullOrEmpty(src));
-        }
-    }
-}

+ 0 - 36
Test/Masuit.Tools.Test2222222222/LinqExtensionTest.cs

@@ -1,36 +0,0 @@
-using Masuit.Tools.Linq;
-using System;
-using System.Linq.Expressions;
-using Xunit;
-
-namespace Masuit.Tools.Test
-{
-    public class LinqExtensionTest
-    {
-        [Fact]
-        public void And_TwoBoolExpression()
-        {
-            //arrange
-            Expression<Func<string, bool>> where1 = s => s.StartsWith("a");
-            Expression<Func<string, bool>> where2 = s => s.Length > 10;
-            Func<string, bool> func = where1.And(where2).Compile();
-
-            //act assert
-            Assert.False(func("abc"));
-            Assert.True(func("abcd12345678"));
-        }
-        [Fact]
-        public void Or_TwoBoolExpression()
-        {
-            //arrange
-            Expression<Func<string, bool>> where1 = s => s.StartsWith("a");
-            Expression<Func<string, bool>> where2 = s => s.Length > 10;
-            Func<string, bool> func = where1.Or(where2).Compile();
-
-            //act assert
-            Assert.True(func("abc"));
-            Assert.True(func("abcd12345678"));
-            Assert.False(func("cbcd12348"));
-        }
-    }
-}

+ 0 - 170
Test/Masuit.Tools.Test2222222222/Masuit.Tools.Test.csproj

@@ -1,170 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project ToolsVersion="15.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
-  <Import Project="..\..\packages\xunit.core.2.4.1\build\xunit.core.props" Condition="Exists('..\..\packages\xunit.core.2.4.1\build\xunit.core.props')" />
-  <Import Project="..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.props" Condition="Exists('..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.props')" />
-  <Import Project="..\packages\NUnit.3.12.0\build\NUnit.props" Condition="Exists('..\packages\NUnit.3.12.0\build\NUnit.props')" />
-  <Import Project="..\packages\xunit.core.2.4.1\build\xunit.core.props" Condition="Exists('..\packages\xunit.core.2.4.1\build\xunit.core.props')" />
-  <Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
-  <PropertyGroup>
-    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
-    <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
-    <ProjectGuid>{174474CB-0C9A-4C99-B461-1A2158F00A98}</ProjectGuid>
-    <OutputType>Library</OutputType>
-    <AppDesignerFolder>Properties</AppDesignerFolder>
-    <RootNamespace>Masuit.Tools.UnitTest</RootNamespace>
-    <AssemblyName>Masuit.Tools.UnitTest</AssemblyName>
-    <TargetFrameworkVersion>v4.6.1</TargetFrameworkVersion>
-    <FileAlignment>512</FileAlignment>
-    <ProjectTypeGuids>{3AC096D0-A1C2-E12C-1390-A8335801FDAB};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}</ProjectTypeGuids>
-    <VisualStudioVersion Condition="'$(VisualStudioVersion)' == ''">15.0</VisualStudioVersion>
-    <VSToolsPath Condition="'$(VSToolsPath)' == ''">$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)</VSToolsPath>
-    <ReferencePath>$(ProgramFiles)\Common Files\microsoft shared\VSTT\$(VisualStudioVersion)\UITestExtensionPackages</ReferencePath>
-    <IsCodedUITest>False</IsCodedUITest>
-    <TestProjectType>UnitTest</TestProjectType>
-    <NuGetPackageImportStamp>
-    </NuGetPackageImportStamp>
-  </PropertyGroup>
-  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
-    <DebugSymbols>true</DebugSymbols>
-    <DebugType>full</DebugType>
-    <Optimize>false</Optimize>
-    <OutputPath>bin\Debug\</OutputPath>
-    <DefineConstants>DEBUG;TRACE</DefineConstants>
-    <ErrorReport>prompt</ErrorReport>
-    <WarningLevel>4</WarningLevel>
-    <LangVersion>8.0</LangVersion>
-  </PropertyGroup>
-  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
-    <DebugType>pdbonly</DebugType>
-    <Optimize>true</Optimize>
-    <OutputPath>bin\Release\</OutputPath>
-    <DefineConstants>TRACE</DefineConstants>
-    <ErrorReport>prompt</ErrorReport>
-    <WarningLevel>4</WarningLevel>
-    <LangVersion>8.0</LangVersion>
-  </PropertyGroup>
-  <ItemGroup>
-    <Reference Include="Microsoft.CSharp" />
-    <Reference Include="Microsoft.VisualStudio.TestPlatform.TestFramework, Version=14.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a, processorArchitecture=MSIL">
-      <HintPath>..\packages\MSTest.TestFramework.2.1.2\lib\net45\Microsoft.VisualStudio.TestPlatform.TestFramework.dll</HintPath>
-    </Reference>
-    <Reference Include="Microsoft.VisualStudio.TestPlatform.TestFramework.Extensions, Version=14.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a, processorArchitecture=MSIL">
-      <HintPath>..\packages\MSTest.TestFramework.2.1.2\lib\net45\Microsoft.VisualStudio.TestPlatform.TestFramework.Extensions.dll</HintPath>
-    </Reference>
-    <Reference Include="Microsoft.Web.Infrastructure, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.Web.Infrastructure.1.0.0.0\lib\net40\Microsoft.Web.Infrastructure.dll</HintPath>
-    </Reference>
-    <Reference Include="Moq, Version=4.14.0.0, Culture=neutral, PublicKeyToken=69f491c39445e920, processorArchitecture=MSIL">
-      <HintPath>..\packages\Moq.4.14.5\lib\net45\Moq.dll</HintPath>
-    </Reference>
-    <Reference Include="nunit.framework, Version=3.12.0.0, Culture=neutral, PublicKeyToken=2638cd05610744eb, processorArchitecture=MSIL">
-      <HintPath>..\packages\NUnit.3.12.0\lib\net45\nunit.framework.dll</HintPath>
-    </Reference>
-    <Reference Include="System" />
-    <Reference Include="System.Configuration" />
-    <Reference Include="System.Core" />
-    <Reference Include="System.Net.Http" />
-    <Reference Include="System.Numerics" />
-    <Reference Include="System.Runtime.CompilerServices.Unsafe, Version=4.0.6.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a, processorArchitecture=MSIL">
-      <HintPath>..\packages\System.Runtime.CompilerServices.Unsafe.4.7.1\lib\net461\System.Runtime.CompilerServices.Unsafe.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Threading.Tasks.Extensions, Version=4.2.0.1, Culture=neutral, PublicKeyToken=cc7b13ffcd2ddd51, processorArchitecture=MSIL">
-      <HintPath>..\packages\System.Threading.Tasks.Extensions.4.5.4\lib\net461\System.Threading.Tasks.Extensions.dll</HintPath>
-    </Reference>
-    <Reference Include="System.ValueTuple, Version=4.0.3.0, Culture=neutral, PublicKeyToken=cc7b13ffcd2ddd51, processorArchitecture=MSIL">
-      <HintPath>..\packages\System.ValueTuple.4.5.0\lib\net461\System.ValueTuple.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Web" />
-    <Reference Include="System.Web.Helpers, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.WebPages.3.2.7\lib\net45\System.Web.Helpers.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Web.Mvc, Version=5.2.7.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.Mvc.5.2.7\lib\net45\System.Web.Mvc.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Web.Razor, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.Razor.3.2.7\lib\net45\System.Web.Razor.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Web.WebPages, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.WebPages.3.2.7\lib\net45\System.Web.WebPages.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Web.WebPages.Deployment, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.WebPages.3.2.7\lib\net45\System.Web.WebPages.Deployment.dll</HintPath>
-    </Reference>
-    <Reference Include="System.Web.WebPages.Razor, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
-      <HintPath>..\packages\Microsoft.AspNet.WebPages.3.2.7\lib\net45\System.Web.WebPages.Razor.dll</HintPath>
-    </Reference>
-    <Reference Include="xunit.abstractions, Version=2.0.0.0, Culture=neutral, PublicKeyToken=8d05b1bb7a6fdb6c, processorArchitecture=MSIL">
-      <HintPath>..\packages\xunit.abstractions.2.0.3\lib\net35\xunit.abstractions.dll</HintPath>
-    </Reference>
-    <Reference Include="xunit.assert, Version=2.4.1.0, Culture=neutral, PublicKeyToken=8d05b1bb7a6fdb6c, processorArchitecture=MSIL">
-      <HintPath>..\..\packages\xunit.assert.2.4.1\lib\netstandard1.1\xunit.assert.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="xunit.core, Version=2.4.1.0, Culture=neutral, PublicKeyToken=8d05b1bb7a6fdb6c, processorArchitecture=MSIL">
-      <HintPath>..\..\packages\xunit.extensibility.core.2.4.1\lib\net452\xunit.core.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-    <Reference Include="xunit.execution.desktop, Version=2.4.1.0, Culture=neutral, PublicKeyToken=8d05b1bb7a6fdb6c, processorArchitecture=MSIL">
-      <HintPath>..\..\packages\xunit.extensibility.execution.2.4.1\lib\net452\xunit.execution.desktop.dll</HintPath>
-      <Private>True</Private>
-    </Reference>
-  </ItemGroup>
-  <ItemGroup>
-    <Compile Include="ChineseCalendarTest.cs" />
-    <Compile Include="Reflection\ClassHelperTest.cs" />
-    <Compile Include="CompressTest.cs" />
-    <Compile Include="ExtensionMethodsTest.cs" />
-    <Compile Include="HtmlToolsTest.cs" />
-    <Compile Include="LinqExtensionTest.cs" />
-    <Compile Include="Mvc\BaseTests.cs" />
-    <Compile Include="Mvc\Mocks\MockHttpFilesCollection.cs" />
-    <Compile Include="Mvc\Mocks\MockHttpPostedFileBase.cs" />
-    <Compile Include="Mvc\Mocks\MockHttpRequest.cs" />
-    <Compile Include="Mvc\Mocks\MockHttpResponse.cs" />
-    <Compile Include="Mvc\Mocks\MockHttpSession.cs" />
-    <Compile Include="Mvc\Mocks\MockRequestContext.cs" />
-    <Compile Include="Mvc\Mocks\MockResumeFileResult.cs" />
-    <Compile Include="Mvc\ResumeFileResultTests.cs" />
-    <Compile Include="NumberFormaterTest.cs" />
-    <Compile Include="Properties\AssemblyInfo.cs" />
-    <Compile Include="RSATest.cs" />
-    <Compile Include="TemplateTest.cs" />
-  </ItemGroup>
-  <ItemGroup>
-    <None Include="app.config" />
-  </ItemGroup>
-  <ItemGroup>
-    <ProjectReference Include="..\..\Masuit.Tools\Masuit.Tools.csproj">
-      <Project>{275d5a0d-c49c-497e-a4b5-f40285c2495f}</Project>
-      <Name>Masuit.Tools</Name>
-    </ProjectReference>
-  </ItemGroup>
-  <ItemGroup>
-    <Analyzer Include="..\packages\xunit.analyzers.0.10.0\analyzers\dotnet\cs\xunit.analyzers.dll" />
-  </ItemGroup>
-  <ItemGroup>
-    <Content Include="Resources\download-test-file.txt">
-      <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
-    </Content>
-    <Content Include="Resources\download-test-file2.txt">
-      <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
-    </Content>
-  </ItemGroup>
-  <Import Project="$(VSToolsPath)\TeamTest\Microsoft.TestTools.targets" Condition="Exists('$(VSToolsPath)\TeamTest\Microsoft.TestTools.targets')" />
-  <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
-  <Target Name="EnsureNuGetPackageBuildImports" BeforeTargets="PrepareForBuild">
-    <PropertyGroup>
-      <ErrorText>这台计算机上缺少此项目引用的 NuGet 程序包。使用“NuGet 程序包还原”可下载这些程序包。有关更多信息,请参见 http://go.microsoft.com/fwlink/?LinkID=322105。缺少的文件是 {0}。</ErrorText>
-    </PropertyGroup>
-    <Error Condition="!Exists('..\packages\xunit.core.2.4.1\build\xunit.core.props')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\xunit.core.2.4.1\build\xunit.core.props'))" />
-    <Error Condition="!Exists('..\packages\xunit.core.2.4.1\build\xunit.core.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\xunit.core.2.4.1\build\xunit.core.targets'))" />
-    <Error Condition="!Exists('..\packages\NUnit.3.12.0\build\NUnit.props')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\NUnit.3.12.0\build\NUnit.props'))" />
-    <Error Condition="!Exists('..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.props')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.props'))" />
-    <Error Condition="!Exists('..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.targets'))" />
-    <Error Condition="!Exists('..\..\packages\xunit.core.2.4.1\build\xunit.core.props')" Text="$([System.String]::Format('$(ErrorText)', '..\..\packages\xunit.core.2.4.1\build\xunit.core.props'))" />
-    <Error Condition="!Exists('..\..\packages\xunit.core.2.4.1\build\xunit.core.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\..\packages\xunit.core.2.4.1\build\xunit.core.targets'))" />
-  </Target>
-  <Import Project="..\packages\xunit.core.2.4.1\build\xunit.core.targets" Condition="Exists('..\packages\xunit.core.2.4.1\build\xunit.core.targets')" />
-  <Import Project="..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.targets" Condition="Exists('..\packages\MSTest.TestAdapter.2.1.2\build\net45\MSTest.TestAdapter.targets')" />
-  <Import Project="..\..\packages\xunit.core.2.4.1\build\xunit.core.targets" Condition="Exists('..\..\packages\xunit.core.2.4.1\build\xunit.core.targets')" />
-</Project>

+ 0 - 84
Test/Masuit.Tools.Test2222222222/Mvc/BaseTests.cs

@@ -1,84 +0,0 @@
-using Masuit.Tools.UnitTest.Mvc.Mocks;
-using Moq;
-using NUnit.Framework;
-using System;
-using System.IO;
-using System.Web;
-using System.Web.Mvc;
-using System.Web.Routing;
-
-namespace Masuit.Tools.Test.Mvc
-{
-    [TestFixture]
-    public abstract class BaseTests
-    {
-        protected internal MockHttpResponse Response { get; set; }
-        protected internal HttpContextBase Context { get; set; }
-        protected internal MockHttpRequest Request { get; set; }
-        protected internal MockHttpSession Session { get; private set; }
-
-        protected string TestDirectoryPath()
-        {
-            return new DirectoryInfo(AppContext.BaseDirectory + ".\\Resources").FullName;
-        }
-
-        protected FileInfo TestFile(string fileName)
-        {
-            return new FileInfo($"{TestDirectoryPath()}\\{fileName}");
-        }
-
-        protected string FilePath(string fileName)
-        {
-            return TestFile(fileName).FullName;
-        }
-
-        protected BaseTests()
-        {
-            InitMocks();
-        }
-
-        [SetUp]
-        public void BaseTestsSetup()
-        {
-            InitMocks();
-        }
-
-        protected void InitMocks()
-        {
-            var mockHttpContext = new Mock<HttpContextBase>();
-            Context = mockHttpContext.Object;
-            Session = new MockHttpSession();
-            Request = new MockHttpRequest(new MockHttpFilesCollection(null));
-            Response = new MockHttpResponse();
-
-            mockHttpContext.Setup(ctx => ctx.Session).Returns(() => Session);
-            mockHttpContext.Setup(ctx => ctx.Request).Returns(() => Request);
-            mockHttpContext.Setup(ctx => ctx.Response).Returns(() => Response);
-            mockHttpContext.Setup(ctx => ctx.Cache).Returns(() => HttpRuntime.Cache);
-        }
-
-        protected ControllerContext ControllerContext<T>(T controller) where T : ControllerBase
-        {
-            return new ControllerContext(Context, new RouteData(), controller);
-        }
-
-        protected ModelBindingContext BindingContext<T>()
-        {
-            return new ModelBindingContext
-            {
-                ModelMetadata = ModelMetadataProviders.Current.GetMetadataForType(null, typeof(T))
-            };
-        }
-
-        protected T MockObject<T>() where T : class
-        {
-            var mock = new Mock<T>();
-            return mock.Object;
-        }
-
-        protected Mock<T> Mock<T>() where T : class
-        {
-            return new Mock<T>();
-        }
-    }
-}

+ 0 - 82
Test/Masuit.Tools.Test2222222222/Mvc/MimeMapperTests.cs

@@ -1,82 +0,0 @@
-// ReSharper disable InconsistentNaming
-
-using Masuit.Tools.Mvc.Mime;
-using NUnit.Framework;
-
-namespace Masuit.Tools.UnitTest.Mvc
-{
-    [TestFixture]
-    public class MimeMapperTests
-    {
-        private IMimeMapper _mapper;
-
-        [SetUp]
-        public void Setup()
-        {
-            _mapper = new MimeMapper();
-        }
-
-        [Test]
-        public void GetDefaultExtension()
-        {
-            Assert.AreEqual("text/plain", _mapper.GetMimeFromExtension("txt"));
-        }
-
-        [Test]
-        public void Search_Works_For_Extensions_With_Dot_As_Well()
-        {
-            Assert.IsNotNull(_mapper.GetMimeFromExtension("css"));
-            Assert.AreEqual(_mapper.GetMimeFromExtension("css"), _mapper.GetMimeFromExtension(".css"));
-        }
-
-        [Test]
-        public void It_Returns_Default_Mime_For_Null_In_Extension()
-        {
-            Assert.AreEqual("application/octet-stream", _mapper.GetMimeFromExtension(null));
-        }
-
-        [Test]
-        public void It_Returns_Default_Mime_For_Not_Found_Extension()
-        {
-            Assert.AreEqual("application/octet-stream", _mapper.GetMimeFromExtension("not found"));
-        }
-
-        [Test]
-        public void It_Searches_In_Full_Path()
-        {
-            Assert.AreEqual("image/gif", _mapper.GetMimeFromPath("C:\\folder1\\folder2\\text.gif"));
-        }
-
-        [Test]
-        public void It_Searches_In_Relative_Path()
-        {
-            Assert.AreEqual("image/gif", _mapper.GetMimeFromPath("..\\..\\..\\text.gif"));
-        }
-
-        [Test]
-        public void Extension_Overrides_Default_Mime()
-        {
-            _mapper = new MimeMapper(new MimeMappingItem
-            {
-                Extension = "txt",
-                MimeType = "my own mime type"
-            });
-            Assert.AreEqual("my own mime type", _mapper.GetMimeFromPath(".txt"));
-            Assert.AreEqual("my own mime type", _mapper.GetMimeFromPath("..\\..\\..\\text.txt"));
-        }
-
-        [Test]
-        public void Search_Works_For_Files_With_Dots_In_Name()
-        {
-            Assert.AreEqual("text/javascript", _mapper.GetMimeFromPath("jquery.min.js"));
-            Assert.AreEqual("text/javascript", _mapper.GetMimeFromPath("http://example.com/jquery.min.js"));
-        }
-
-        [Test]
-        public void It_Returns_Default_Mime_For_Files_Without_Extension()
-        {
-            Assert.AreEqual("application/octet-stream", _mapper.GetMimeFromPath("testfile"));
-            Assert.AreEqual("application/octet-stream", _mapper.GetMimeFromPath("\\\\network\\share\\testfile"));
-        }
-    }
-}

+ 0 - 35
Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockHttpFilesCollection.cs

@@ -1,35 +0,0 @@
-using Mvc.Stream.Tests.Mocks;
-using System.Collections.Generic;
-using System.Linq;
-using System.Web;
-
-namespace Masuit.Tools.Test.Mvc.Mocks
-{
-    public class MockHttpFilesCollection : HttpFileCollectionBase
-    {
-        private readonly Dictionary<string, MockHttpPostedFileBase> _files
-            = new Dictionary<string, MockHttpPostedFileBase>();
-
-        public MockHttpFilesCollection(MockHttpPostedFileBase file)
-        {
-            if (file != null)
-            {
-                _files.Add(file.FileName, file);
-            }
-        }
-
-        public override int Count => _files.Count;
-
-        public override HttpPostedFileBase this[int index] => _files.Skip(index).Take(1).FirstOrDefault().Value;
-
-        public override HttpPostedFileBase this[string name] => _files[name];
-
-        public override string[] AllKeys
-        {
-            get
-            {
-                return _files.Select(x => x.Key).ToArray();
-            }
-        }
-    }
-}

+ 0 - 40
Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockHttpPostedFileBase.cs

@@ -1,40 +0,0 @@
-using System.IO;
-using System.Web;
-
-namespace Mvc.Stream.Tests.Mocks
-{
-    public class MockHttpPostedFileBase : HttpPostedFileBase
-    {
-        public MockHttpPostedFileBase(int contentLen, string fileName, string contentType, System.IO.Stream stream = null)
-        {
-            ContentLength = contentLen;
-            FileName = fileName;
-            ContentType = contentType;
-            InputStream = stream;
-        }
-
-        public override int ContentLength { get; }
-
-        public override string FileName { get; }
-
-        public override System.IO.Stream InputStream { get; }
-
-        public override string ContentType { get; }
-
-        public override void SaveAs(string filename)
-        {
-            var fileInfo = new FileInfo(filename);
-            var directory = new DirectoryInfo(Path.GetDirectoryName(fileInfo.FullName));
-
-            if (!directory.Exists)
-            {
-                directory.Create();
-            }
-
-            using (var file = fileInfo.CreateText())
-            {
-                file.Write("test");
-            }
-        }
-    }
-}

+ 0 - 61
Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockHttpRequest.cs

@@ -1,61 +0,0 @@
-using System;
-using System.Collections.Specialized;
-using System.IO;
-using System.Web;
-using System.Web.Routing;
-
-namespace Masuit.Tools.Test.Mvc.Mocks
-{
-    public class MockHttpRequest : HttpRequestBase
-    {
-        public override NameValueCollection Headers => _headers;
-
-        public override HttpFileCollectionBase Files { get; }
-
-        public override RequestContext RequestContext => _context;
-        public override string ApplicationPath => _applicationPath;
-
-        public override System.IO.Stream InputStream
-        {
-            get
-            {
-                if (TestInput != null)
-                {
-                    var stream = new MemoryStream();
-                    var chars = TestInput.ToCharArray();
-                    foreach (var c in chars)
-                    {
-                        stream.WriteByte(Convert.ToByte(c));
-                    }
-                    return stream;
-                }
-                return new MemoryStream();
-            }
-        }
-
-        public override string HttpMethod => TestHttpMethod;
-        private readonly NameValueCollection _headers = new NameValueCollection();
-        private readonly MockRequestContext _context = new MockRequestContext();
-        private string _applicationPath;
-        public string TestInput;
-
-        public string TestHttpMethod;
-
-        public MockHttpRequest(MockHttpFilesCollection filesMock)
-        {
-            Files = filesMock;
-        }
-
-        public MockHttpRequest SetHeader(string header, string val)
-        {
-            _headers[header] = val;
-            return this;
-        }
-
-        public MockHttpRequest SetApplicationPath(string path)
-        {
-            _applicationPath = path;
-            return this;
-        }
-    }
-}

+ 0 - 84
Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockHttpResponse.cs

@@ -1,84 +0,0 @@
-using System.Collections.Specialized;
-using System.IO;
-using System.Web;
-
-namespace Masuit.Tools.Test.Mvc.Mocks
-{
-    public class MockHttpResponse : HttpResponseBase
-    {
-        public override NameValueCollection Headers => _headers;
-
-        public bool FileTransmitted { get; set; }
-        public override bool BufferOutput { get; set; }
-
-        public override System.IO.Stream OutputStream => _stream ?? (_stream = new MemoryStream());
-
-        public override bool IsClientConnected => true;
-
-        public override string ContentType { get; set; }
-
-        public override int StatusCode { get; set; }
-
-        private readonly NameValueCollection _headers = new NameValueCollection();
-
-        private MemoryStream _stream;
-
-        public bool IsClosed;
-
-        public override void AppendHeader(string name, string value)
-        {
-            AddHeader(name, value);
-        }
-
-        public override void AddHeader(string name, string value)
-        {
-            _headers.Add(name, value);
-        }
-
-        public void ClearTestResponse()
-        {
-            _stream = new MemoryStream();
-            Headers.Clear();
-            StatusCode = 0;
-        }
-
-        public override void Flush()
-        {
-        }
-
-        public override void Write(string s)
-        {
-        }
-
-        public override void Close()
-        {
-            IsClosed = true;
-        }
-
-        public override void TransmitFile(string filename)
-        {
-            FileTransmitted = true;
-            var fi = new FileInfo(filename);
-            using (var read = fi.OpenRead())
-            {
-                for (var i = 0; i < fi.Length; i++)
-                {
-                    OutputStream.WriteByte((byte)read.ReadByte());
-                }
-            }
-        }
-
-        public override void TransmitFile(string filename, long offset, long length)
-        {
-            var fi = new FileInfo(filename);
-            using (var read = fi.OpenRead())
-            {
-                read.Seek(offset, SeekOrigin.Begin);
-                for (var i = 0; i < length; i++)
-                {
-                    OutputStream.WriteByte((byte)read.ReadByte());
-                }
-            }
-        }
-    }
-}

+ 0 - 36
Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockHttpSession.cs

@@ -1,36 +0,0 @@
-using System.Collections.Generic;
-using System.Web;
-
-namespace Masuit.Tools.Test.Mvc.Mocks
-{
-    public class MockHttpSession : HttpSessionStateBase
-    {
-        private readonly Dictionary<string, object> _sessionStorage = new Dictionary<string, object>();
-        private string _sessionId = "0000-0000";
-
-        public override object this[string name]
-        {
-            get
-            {
-                _sessionStorage.TryGetValue(name, out var val);
-                return val;
-            }
-            set => _sessionStorage[name] = value;
-        }
-
-        public void SetSessionId(string sessionId)
-        {
-            _sessionId = sessionId;
-        }
-
-        public override string SessionID => _sessionId;
-
-        public override void Remove(string name)
-        {
-            if (_sessionStorage.ContainsKey(name))
-            {
-                _sessionStorage.Remove(name);
-            }
-        }
-    }
-}

+ 0 - 8
Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockRequestContext.cs

@@ -1,8 +0,0 @@
-using System.Web.Routing;
-
-namespace Masuit.Tools.Test.Mvc.Mocks
-{
-    public class MockRequestContext : RequestContext
-    {
-    }
-}

+ 0 - 46
Test/Masuit.Tools.Test2222222222/Mvc/Mocks/MockResumeFileResult.cs

@@ -1,46 +0,0 @@
-using Masuit.Tools.Mvc.ActionResults;
-using System.Web;
-
-namespace Masuit.Tools.Test.Mvc.Mocks
-{
-    public class MockResumeFileResult : ResumeFileResult
-    {
-        public MockResumeFileResult(string fileName, HttpRequestBase request) : base(fileName, request)
-        {
-        }
-
-        public MockResumeFileResult(string fileName, HttpRequestBase request, string downloadFileName) : base(fileName, request, downloadFileName)
-        {
-        }
-
-        public new bool IsNotModified()
-        {
-            return base.IsNotModified();
-        }
-
-        public new bool IsPreconditionFailed()
-        {
-            return base.IsPreconditionFailed();
-        }
-
-        public new bool IsRangeNotSatisfiable()
-        {
-            return base.IsRangeNotSatisfiable();
-        }
-
-        public new bool SendRange()
-        {
-            return base.SendRange();
-        }
-
-        public void WriteFileTest(HttpResponseBase response)
-        {
-            base.WriteFile(response);
-        }
-
-        public void TransmitTest(HttpResponseBase response)
-        {
-            base.TransmitFile(response);
-        }
-    }
-}

+ 0 - 505
Test/Masuit.Tools.Test2222222222/Mvc/ResumeFileResultTests.cs

@@ -1,505 +0,0 @@
-using Masuit.Tools.Mvc;
-using Masuit.Tools.Mvc.ActionResults;
-using Masuit.Tools.UnitTest.Mvc.Mocks;
-using NUnit.Framework;
-using System;
-using System.IO;
-using System.Net;
-using System.Threading;
-
-namespace Masuit.Tools.Test.Mvc
-{
-    [TestFixture]
-    public class ResumeFileResultTests : BaseTests
-    {
-        private FileInfo _file;
-        private FileInfo _file2;
-
-        [SetUp]
-        public void Setup()
-        {
-            _file = new FileInfo(FilePath("download-test-file.txt"));
-            _file2 = new FileInfo(FilePath("download-test-file2.txt"));
-            Request.Headers.Clear();
-            Response.ClearTestResponse();
-        }
-
-        [Test]
-        public void CanCalculateEtagForFile()
-        {
-            Assert.IsNotNull(ResumeFileResult.Util.Etag(_file));
-        }
-
-        [Test]
-        public void EtagDoesNotDependOnTime()
-        {
-            var etag1 = ResumeFileResult.Util.Etag(_file);
-            Thread.Sleep(100);
-            var etag2 = ResumeFileResult.Util.Etag(_file);
-            Assert.AreEqual(etag1, etag2);
-        }
-
-        [Test]
-        public void EtagDoesDependOnFile()
-        {
-            var etag1 = ResumeFileResult.Util.Etag(_file);
-            Thread.Sleep(100);
-            var etag2 = ResumeFileResult.Util.Etag(_file2);
-            Assert.AreNotEqual(etag1, etag2);
-        }
-
-        [Test]
-        public void IsNotModified_Is_False_If_IfNoneMatch_And_IfModifiedSince_Are_Empty()
-        {
-            Request.Headers[HttpHeaders.IfNoneMatch] = null;
-            Request.Headers[HttpHeaders.IfModifiedSince] = null;
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).IsNotModified());
-        }
-
-        [Test]
-        public void IsNotModified_Is_False_If_Etag_Is_Invalid_And_IfModifiedSince_Is_Null()
-        {
-            var etag = "invalid etag";
-            Request.Headers[HttpHeaders.IfNoneMatch] = etag;
-            Request.Headers[HttpHeaders.IfModifiedSince] = null;
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).IsNotModified());
-        }
-
-        [Test]
-        public void IsNotModified_Is_True_If_Etag_Is_Valid()
-        {
-            var etag = ResumeFileResult.Util.Etag(_file);
-            Request.Headers[HttpHeaders.IfNoneMatch] = etag;
-            Assert.IsTrue(new MockResumeFileResult(_file.FullName, Request).IsNotModified());
-        }
-
-        [Test]
-        public void IsNotModified_Is_True_If_Etag_Is_Star()
-        {
-            var etag = "*";
-            Request.Headers[HttpHeaders.IfNoneMatch] = etag;
-            Assert.IsTrue(new MockResumeFileResult(_file.FullName, Request).IsNotModified());
-        }
-
-        [Test]
-        public void IsNotModified_Is_False_If_Etag_Is_Empty_And_IfModifiedSince_Is_Invalid()
-        {
-            Request.Headers[HttpHeaders.IfModifiedSince] = DateTime.Now.ToString("R");
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).IsNotModified());
-        }
-
-        [Test]
-        public void IsNotModified_Is_False_If_Etag_Is_Empty_And_IfModifiedSince_Is_LastFileWriteTime()
-        {
-            Request.Headers[HttpHeaders.IfModifiedSince] = _file.LastWriteTime.ToString("R");
-            Assert.IsTrue(new MockResumeFileResult(_file.FullName, Request).IsNotModified());
-        }
-
-        [Test]
-        public void IsPreconditionFailedTest_Is_False_If_ifMatch_And_ifUnmodifiedSince_Are_Empty()
-        {
-            Request.Headers[HttpHeaders.IfMatch] = null;
-            Request.Headers[HttpHeaders.IfUnmodifiedSince] = null;
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).IsPreconditionFailed());
-        }
-
-        [Test]
-        public void IsPreconditionFailedTest_Is_IsTrue_If_ifMatch_Doesnot_Match_Etag_Of_The_File()
-        {
-            Request.Headers[HttpHeaders.IfMatch] = "incorrect";
-            Assert.IsTrue(new MockResumeFileResult(_file.FullName, Request).IsPreconditionFailed());
-        }
-
-        [Test]
-        public void IsPreconditionFailedTest_Is_IsFalse_If_ifMatch_Matches_Etag_Of_The_File()
-        {
-            Request.Headers[HttpHeaders.IfMatch] = ResumeFileResult.Util.Etag(_file);
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).IsPreconditionFailed());
-        }
-
-        [Test]
-        public void IsPreconditionFailedTest_Is_IsFalse_If_ifMatch_Equals_Star()
-        {
-            Request.Headers[HttpHeaders.IfMatch] = "*";
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).IsPreconditionFailed());
-        }
-
-        [Test]
-        public void IsPreconditionFailedTest_Is_IsTrue_If_ifUnmodifiedSince_Doesnot_Equal_FileLastWriteTime()
-        {
-            Request.Headers[HttpHeaders.IfUnmodifiedSince] = DateTime.Now.ToString("R");
-            Assert.IsTrue(new MockResumeFileResult(_file.FullName, Request).IsPreconditionFailed());
-        }
-
-        [Test]
-        public void IsPreconditionFailedTest_Is_IsFalse_If_ifUnmodifiedSince_Equals_FileLastWriteTime()
-        {
-            Request.Headers[HttpHeaders.IfUnmodifiedSince] = _file.LastWriteTime.ToString("R");
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).IsPreconditionFailed());
-        }
-
-        [Test]
-        public void IsRangeNotSatisfiable_Is_True_If_Range_Header_Has_Invalid_Format()
-        {
-            Request.Headers[HttpHeaders.Range] = "blah";
-            Assert.IsTrue(new MockResumeFileResult(_file.FullName, Request).IsRangeNotSatisfiable());
-        }
-
-        [Test]
-        public void IsRangeNotSatisfiable_Is_True_If_Start_Greater_Than_End()
-        {
-            Request.Headers[HttpHeaders.Range] = "bytes=100-0";
-            Assert.IsTrue(new MockResumeFileResult(_file.FullName, Request).IsRangeNotSatisfiable());
-        }
-
-        [Test]
-        public void IsRangeNotSatisfiable_Is_True_If_End_Equals_Total_File_Size()
-        {
-            Request.Headers[HttpHeaders.Range] = "bytes=0-" + _file.Length;
-            Assert.IsTrue(new MockResumeFileResult(_file.FullName, Request).IsRangeNotSatisfiable());
-        }
-
-        [Test]
-        public void IsRangeNotSatisfiable_Is_True_If_End_Greater_Than_Total_File_Size()
-        {
-            Request.Headers[HttpHeaders.Range] = "bytes=0-" + _file.Length + 10;
-            Assert.IsTrue(new MockResumeFileResult(_file.FullName, Request).IsRangeNotSatisfiable());
-        }
-
-        [Test]
-        public void IsRangeNotSatisfiable_Is_False_If_Range_Header_Is_Null()
-        {
-            Request.Headers[HttpHeaders.Range] = null;
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).IsRangeNotSatisfiable());
-        }
-
-        [Test]
-        public void IsRangeNotSatisfiable_Is_False_If_Range_Has_StartsWith_Format()
-        {
-            Request.Headers[HttpHeaders.Range] = "bytes=0-";
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).IsRangeNotSatisfiable());
-        }
-
-        [Test]
-        public void IsRangeNotSatisfiable_Is_False_If_Range_Has_LastXbytes_Format()
-        {
-            Request.Headers[HttpHeaders.Range] = "bytes=-100";
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).IsRangeNotSatisfiable());
-        }
-
-        [Test]
-        public void IsRangeNotSatisfiable_Is_False_If_Range_Ends_With_Last_Byte_Position()
-        {
-            Request.Headers[HttpHeaders.Range] = "bytes=100-" + (_file.Length - 1);
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).IsRangeNotSatisfiable());
-        }
-
-        [Test]
-        public void SendRange_Is_False_If_Range_And_ifRange_Headers_Are_Null()
-        {
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).SendRange());
-        }
-
-        [Test]
-        public void SendRange_Is_False_If_Range_Is_Null_And_ifRange_Is_Correct()
-        {
-            Request.Headers[HttpHeaders.IfRange] = ResumeFileResult.Util.Etag(_file);
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).SendRange());
-        }
-
-        [Test]
-        public void SendRange_Is_True_If_Range_Is_Correct_And_ifRange_Is_Null()
-        {
-            Request.Headers[HttpHeaders.Range] = "bytes=0-100";
-            Assert.IsTrue(new MockResumeFileResult(_file.FullName, Request).SendRange());
-        }
-
-        [Test]
-        public void SendRange_Is_True_If_Range_And_ifRange_Are_Correct()
-        {
-            Request.Headers[HttpHeaders.IfRange] = ResumeFileResult.Util.Etag(_file);
-            Request.Headers[HttpHeaders.Range] = "bytes=0-100";
-            Assert.IsTrue(new MockResumeFileResult(_file.FullName, Request).SendRange());
-        }
-
-        [Test]
-        public void SendRange_Is_False_If_Range_Is_Correct_But_ifRange_Is_InCorrect()
-        {
-            Request.Headers[HttpHeaders.IfRange] = "incorrect etag";
-            Request.Headers[HttpHeaders.Range] = "bytes=0-100";
-            Assert.IsFalse(new MockResumeFileResult(_file.FullName, Request).SendRange());
-        }
-
-        [Test]
-        public void HeadersTest_Should_Not_Send_File_If_File_Has_Not_Been_Changed()
-        {
-            Request.Headers[HttpHeaders.IfNoneMatch] = ResumeFileResult.Util.Etag(_file);
-            var result = new MockResumeFileResult(_file.FullName, Request);
-            Assert.IsTrue(result.IsNotModified());
-            result.WriteFileTest(Response);
-            Assert.AreEqual((int)HttpStatusCode.NotModified, Response.StatusCode);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.Etag]);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.Expires]);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.LastModified]);
-            Assert.IsNull(Response.Headers[HttpHeaders.ContentRange]);
-            Assert.AreEqual(0, Response.OutputStream.Length);
-        }
-
-        [Test]
-        public void HeadersTest_Should_Not_Send_File_IfPreconditionFailed()
-        {
-            Request.Headers[HttpHeaders.IfMatch] = "invalid";
-            var result = new MockResumeFileResult(_file.FullName, Request);
-            Assert.IsTrue(result.IsPreconditionFailed());
-
-            result.WriteFileTest(Response);
-            Assert.AreEqual((int)HttpStatusCode.PreconditionFailed, Response.StatusCode);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.Etag]);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.Expires]);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.LastModified]);
-            Assert.IsNull(Response.Headers[HttpHeaders.ContentRange]);
-            Assert.AreEqual(0, Response.OutputStream.Length);
-        }
-
-        [Test]
-        public void HeadersTest_Should_Not_Send_File_Is_RangeNotSatisfiable()
-        {
-            Request.Headers[HttpHeaders.Range] = "invalid";
-            var result = new MockResumeFileResult(_file.FullName, Request);
-            Assert.IsTrue(result.IsRangeNotSatisfiable());
-            result.WriteFileTest(Response);
-            Assert.AreEqual((int)HttpStatusCode.RequestedRangeNotSatisfiable, Response.StatusCode);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.Etag]);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.Expires]);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.LastModified]);
-            Assert.AreEqual("bytes */" + _file.Length, Response.Headers[HttpHeaders.ContentRange]);
-            Assert.AreEqual(0, Response.OutputStream.Length);
-        }
-
-        [Test]
-        public void HeadersTest_Should_Send_File_If_All_Headers_Are_Null()
-        {
-            var result = new MockResumeFileResult(_file.FullName, Request);
-            result.WriteFileTest(Response);
-            Assert.AreEqual((int)HttpStatusCode.OK, Response.StatusCode);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.Etag]);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.Expires]);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.LastModified]);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.ContentRange]);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.ContentLength]);
-            Assert.AreEqual(_file.Length, Response.OutputStream.Length);
-        }
-
-        [Test]
-        public void Range_First_500b()
-        {
-            var stream = GetResponseStream("bytes=0-499");
-            Assert.AreEqual(500, stream.Length);
-            Assert.AreEqual(206, Response.StatusCode);
-            Assert.AreEqual($"bytes 0-499/{_file.Length}", Response.Headers[HttpHeaders.ContentRange]);
-        }
-
-        [Test]
-        public void Range_From_500b_to_899b()
-        {
-            var stream = GetResponseStream("bytes=500-899");
-            Assert.AreEqual(400, stream.Length);
-            Assert.AreEqual(206, Response.StatusCode);
-            Assert.AreEqual($"bytes 500-899/{_file.Length}", Response.Headers[HttpHeaders.ContentRange]);
-        }
-
-        [Test]
-        public void Range_Last_300b()
-        {
-            var stream = GetResponseStream("bytes=-300");
-            Assert.AreEqual(300, stream.Length);
-            Assert.AreEqual(206, Response.StatusCode);
-            var from = _file.Length - 300;
-            var to = _file.Length - 1;
-
-            Assert.AreEqual($"bytes {from}-{to}/{_file.Length}", Response.Headers[HttpHeaders.ContentRange]);
-        }
-
-        [Test]
-        public void Range_From_100b_toThe_End()
-        {
-            var stream = GetResponseStream($"bytes={(_file.Length - 100)}-");
-            Assert.AreEqual(100, stream.Length);
-            Assert.AreEqual(206, Response.StatusCode);
-            var from = _file.Length - 100;
-            var to = _file.Length - 1;
-            Assert.AreEqual($"bytes {from}-{to}/{_file.Length}", Response.Headers[HttpHeaders.ContentRange]);
-        }
-
-        [Test]
-        public void Range_First_1b()
-        {
-            var stream = GetResponseStream("bytes=0-0");
-            Assert.AreEqual(1, stream.Length);
-            Assert.AreEqual(206, Response.StatusCode);
-            Assert.AreEqual($"bytes 0-0/{_file.Length}", Response.Headers[HttpHeaders.ContentRange]);
-        }
-
-        [Test]
-        public void Range_Last_1b()
-        {
-            var stream = GetResponseStream("bytes=-1");
-            Assert.AreEqual(1, stream.Length);
-            Assert.AreEqual(206, Response.StatusCode);
-            var from = _file.Length - 1;
-            var to = _file.Length - 1;
-            Assert.AreEqual($"bytes {from}-{to}/{_file.Length}", Response.Headers[HttpHeaders.ContentRange]);
-        }
-
-        [Test]
-        public void Range_Whole_File_With_RangeHeader()
-        {
-            var stream = GetResponseStream("bytes=0-" + (_file.Length - 1));
-            Assert.AreEqual(_file.Length, stream.Length);
-            Assert.AreEqual(206, Response.StatusCode);
-            Assert.AreEqual($"bytes 0-{(_file.Length - 1)}/{_file.Length}", Response.Headers[HttpHeaders.ContentRange]);
-        }
-
-        [Test]
-        public void Range_Whole_File_Without_RangeHeader()
-        {
-            var stream = GetResponseStream(null);
-            Assert.AreEqual(_file.Length, stream.Length);
-            Assert.AreEqual(200, Response.StatusCode);
-            Assert.AreEqual($"bytes 0-{(_file.Length - 1)}/{_file.Length}", Response.Headers[HttpHeaders.ContentRange]);
-        }
-
-        [Test]
-        public void TransmissionRange_From_0_To_0()
-        {
-            Request.Headers[HttpHeaders.Range] = "bytes=0-0";
-            new MockResumeFileResult(_file.FullName, Request).WriteFileTest(Response);
-
-            Assert.AreEqual(1, Response.OutputStream.Length);
-            AssertBytes(_file, Response.OutputStream, 0, 1);
-        }
-
-        [Test]
-        public void TransmissionRange_From_1_To_100()
-        {
-            Request.Headers[HttpHeaders.Range] = "bytes=1-100";
-            new MockResumeFileResult(_file.FullName, Request).WriteFileTest(Response);
-
-            Assert.AreEqual(100, Response.OutputStream.Length);
-            AssertBytes(_file, Response.OutputStream, 1, 100);
-        }
-
-        [Test]
-        public void TransmissionRange_From_101_To_theEnd()
-        {
-            Request.Headers[HttpHeaders.Range] = "bytes=101-";
-            new MockResumeFileResult(_file.FullName, Request).WriteFileTest(Response);
-
-            Assert.AreEqual(_file.Length - 101, Response.OutputStream.Length);
-            AssertBytes(_file, Response.OutputStream, 101, (int)_file.Length);
-        }
-
-        [Test]
-        public void TransmissionRange_WholeFile_WithRangeHeader()
-        {
-            Request.Headers[HttpHeaders.Range] = "bytes=0-";
-            new MockResumeFileResult(_file.FullName, Request).WriteFileTest(Response);
-
-            Assert.AreEqual(_file.Length, Response.OutputStream.Length);
-            AssertBytes(_file, Response.OutputStream, 0, (int)_file.Length);
-        }
-
-        [Test]
-        public void TransmissionRange_WholeFile_WithoutRangeHeader()
-        {
-            Request.Headers[HttpHeaders.Range] = null;
-            new MockResumeFileResult(_file.FullName, Request).WriteFileTest(Response);
-
-            Assert.AreEqual(_file.Length, Response.OutputStream.Length);
-            AssertBytes(_file, Response.OutputStream, 0, (int)_file.Length);
-        }
-
-        [Test]
-        public void ShouldSend206If_Range_HeaderExists()
-        {
-            Request.Headers[HttpHeaders.Range] = "bytes=0-";
-            new MockResumeFileResult(_file.FullName, Request).WriteFileTest(Response);
-            Assert.AreEqual(206, Response.StatusCode);
-        }
-
-        [Test]
-        public void ShouldSend200If_Range_HeaderDoesNotExist()
-        {
-            Request.Headers[HttpHeaders.Range] = null;
-            new MockResumeFileResult(_file.FullName, Request).WriteFileTest(Response);
-            Assert.AreEqual(200, Response.StatusCode);
-        }
-
-        [Test]
-        public void IfRangeHeader_Should_Be_Ignored_If_ItNotEquals_Etag()
-        {
-            Request.Headers[HttpHeaders.IfRange] = "ifRange fake header";
-            var mock = new MockResumeFileResult(_file.FullName, Request);
-            mock.WriteFileTest(Response);
-
-            Assert.AreNotEqual(ResumeFileResult.Util.Etag(_file), Request.Headers[HttpHeaders.IfRange]);
-            Assert.AreEqual(200, Response.StatusCode);
-        }
-
-        [Test]
-        public void Etag_Should_Be_Added_To_Response_If_It_Equals_With_IfRange_In_Request()
-        {
-            var etag = ResumeFileResult.Util.Etag(_file);
-            Request.Headers[HttpHeaders.IfRange] = etag;
-            var mock = new MockResumeFileResult(_file.FullName, Request);
-            mock.WriteFileTest(Response);
-            Assert.AreEqual(Response.Headers[HttpHeaders.Etag], etag);
-            Assert.AreEqual(200, Response.StatusCode);
-        }
-
-        [Test]
-        public void Etag_Should_Be_Added_To_Response_If_It_Equals_With_IfRange_In_Request__PartialResponse()
-        {
-            var etag = ResumeFileResult.Util.Etag(_file);
-            Request.Headers[HttpHeaders.IfRange] = etag;
-            Request.Headers[HttpHeaders.Range] = "bytes=0-";
-            new MockResumeFileResult(_file.FullName, Request).WriteFileTest(Response);
-            Assert.AreEqual(Response.Headers[HttpHeaders.Etag], etag);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.ContentRange]);
-            Assert.AreEqual(206, Response.StatusCode);
-        }
-
-        [Test]
-        public void It_Should_Attach_Content_Disposition_If_There_Is_Download_File_Name()
-        {
-            new MockResumeFileResult(_file.FullName, Request, "test.name").WriteFileTest(Response);
-            Assert.IsNotNull(Response.Headers[HttpHeaders.ContentDisposition]);
-        }
-
-        private Stream GetResponseStream(string range)
-        {
-            Response.ClearTestResponse();
-            Response.StatusCode = 500;
-
-            Request.Headers[HttpHeaders.Range] = range;
-            new MockResumeFileResult(_file.FullName, Request).WriteFileTest(Response);
-
-            return Response.OutputStream;
-        }
-
-        private void AssertBytes(FileInfo file, Stream responseStream, int from, int to)
-        {
-            using (var fileStream = file.OpenRead())
-            {
-                responseStream.Seek(0, SeekOrigin.Begin);
-                fileStream.Seek(from, SeekOrigin.Begin);
-                for (var byteIndex = from; byteIndex < to; byteIndex++)
-                {
-                    var responseByte = responseStream.ReadByte();
-                    var fileByte = fileStream.ReadByte();
-                    Assert.AreEqual(responseByte, fileByte);
-                }
-            }
-        }
-    }
-}

+ 0 - 60
Test/Masuit.Tools.Test2222222222/NumberFormaterTest.cs

@@ -1,60 +0,0 @@
-using Masuit.Tools.Strings;
-using Xunit;
-
-namespace Masuit.Tools.Test
-{
-    public class NumberFormaterTest
-    {
-        [Theory]
-        [InlineData(2, 16, "10000")]
-        [InlineData(8, 8, "10")]
-        [InlineData(16, 16, "10")]
-        [InlineData(36, 36, "10")]
-        [InlineData(62, 62, "10")]
-        public void Can_ConvertOct2AnySystem(int bin, long input, string expectOutput)
-        {
-            var nf = new NumberFormater(bin);
-            string output = nf.ToString(input);
-            Assert.Equal(expectOutput, output);
-        }
-
-        [Theory]
-        [InlineData(2, "10000", 16)]
-        [InlineData(8, "10", 8)]
-        [InlineData(16, "10", 16)]
-        [InlineData(36, "10", 36)]
-        [InlineData(62, "10", 62)]
-        public void Can_ConvertAnySystem2Oct(int bin, string input, long expected)
-        {
-            var nf = new NumberFormater(bin);
-            string output = nf.ToString(expected);
-            Assert.Equal(input, output);
-        }
-
-        [Fact]
-        public void Can_ConvertAnyNum2Chinese()
-        {
-            // arrange
-            double num = 1234567809.321;
-
-            // act
-            var chineseNumber = NumberFormater.ToChineseNumber(num);
-
-            // assert
-            Assert.Equal("十二亿三千四百五十六万七千八百零九点三二一", chineseNumber);
-        }
-
-        [Fact]
-        public void Can_ConvertAnyNum2ChineseMoney()
-        {
-            // arrange
-            double num = 123456789.321;
-
-            // act
-            var chineseNumber = NumberFormater.ToChineseMoney(num);
-
-            // assert
-            Assert.Equal("壹億贰仟叁佰肆拾伍萬陆仟柒佰捌拾玖元叁角贰分", chineseNumber);
-        }
-    }
-}

+ 0 - 19
Test/Masuit.Tools.Test2222222222/Properties/AssemblyInfo.cs

@@ -1,19 +0,0 @@
-using System.Reflection;
-using System.Runtime.InteropServices;
-
-[assembly: AssemblyTitle("Masuit.Tools.UnitTest")]
-[assembly: AssemblyDescription("")]
-[assembly: AssemblyConfiguration("")]
-[assembly: AssemblyCompany("")]
-[assembly: AssemblyProduct("Masuit.Tools.UnitTest")]
-[assembly: AssemblyCopyright("Copyright ©  2018")]
-[assembly: AssemblyTrademark("")]
-[assembly: AssemblyCulture("")]
-
-[assembly: ComVisible(false)]
-
-[assembly: Guid("174474cb-0c9a-4c99-b461-1a2158f00a98")]
-
-// [assembly: AssemblyVersion("1.0.*")]
-[assembly: AssemblyVersion("1.0.0.0")]
-[assembly: AssemblyFileVersion("1.0.0.0")]

+ 0 - 27
Test/Masuit.Tools.Test2222222222/RSATest.cs

@@ -1,27 +0,0 @@
-using Masuit.Tools.Security;
-using Xunit;
-
-namespace Masuit.Tools.Test
-{
-    public class RSATest
-    {
-        [Fact]
-        public void Can_Encrypt()
-        {
-            string publicKey = "<RSAKeyValue><Modulus>w1f5E3UyxPseWA0DKU6hpN/4WetQA8llIsO4YQx+m7wGzhbDTMmx7ScGZlyHAXYaSisUzNMIBJOIEsCtQsH/q2r7kOm7tQqnjYdaBgFrY/LnpsvVCS8mkQylbkdiZyusV09H3zcQ4KOwNUUm0m2wyBY5KoT3m8j1pcIk8id97SU=</Modulus><Exponent>AQAB</Exponent></RSAKeyValue>";
-            string origin = "123456";
-            string enc = origin.RSAEncrypt(publicKey);
-            string dec = enc.RSADecrypt("<RSAKeyValue><Modulus>w1f5E3UyxPseWA0DKU6hpN/4WetQA8llIsO4YQx+m7wGzhbDTMmx7ScGZlyHAXYaSisUzNMIBJOIEsCtQsH/q2r7kOm7tQqnjYdaBgFrY/LnpsvVCS8mkQylbkdiZyusV09H3zcQ4KOwNUUm0m2wyBY5KoT3m8j1pcIk8id97SU=</Modulus><Exponent>AQAB</Exponent><P>0WSGgAK4Xan/2q0oNaVI8CRgLaD9xqK73EkKRumlC44fDTIcXE0vIaPsXeC8A+vHAFjDhC2MEbf30DW2sd2Y+w==</P><Q>7tLqNhL3zQ+8jblh17T9a+nbpQIG54igOlwc3jwa8kUm2rr+QRTUI5MP+diqQoT7z4o1oxFP6+Lsy2dXvv34Xw==</Q><DP>sgvWShcGCa65vYmrPSJUCM4FcgcIgtRxBPieYnndOxwXzzKi5uFCiEpIe/LSLEtZpTPU3BmWlqJld4eU11zj7Q==</DP><DQ>tDZJb6ZegMloIZWKxEeZl02vZVMjPKF3LrKFQhkeyEPwLss9woRiE7oMKx8YUvugPBpxoOwWX8wrnM0NhFyGhw==</DQ><InverseQ>S7ynBGzvO0HQ9+SKiBdz4Sgn7hntSJI7WcHZksfj3R9iN/L1pWVuMSdMg1fI1FUX9heciV2u1QMARYvUNeU5xQ==</InverseQ><D>JqpHFt7fybWa7/rDYW26+ROL6OB22gkHB7aNzEfY16KEBk7jIVPa8AIFdkViQ5vI4F1epJwwvhclm/CfWtNjc4XlhCo09koMnJPvxd0tdhnhtxbUG6gcEQOQUoQoVT7x9Evs33U78307qVT1j67FMUYW0Xanlu79a7Xgt+XyhRE=</D></RSAKeyValue>");
-            Assert.Equal(dec, origin);
-        }
-
-        [Fact]
-        public void Can_EncryptAuto()
-        {
-            string origin = "123456";
-            string enc = origin.RSAEncrypt();
-            string dec = enc.RSADecrypt();
-            Assert.Equal(dec, origin);
-        }
-    }
-}

+ 0 - 52
Test/Masuit.Tools.Test2222222222/Reflection/ClassHelperTest.cs

@@ -1,52 +0,0 @@
-using Masuit.Tools.Reflection;
-using System.Collections.Generic;
-using Xunit;
-
-namespace Masuit.Tools.Test
-{
-    public class ClassHelperTest
-    {
-        [Fact]
-        public void Can_AddProperty_ReturnNewInstance()
-        {
-            // arrange
-            MyClass myClass = new MyClass();
-
-            // act
-            dynamic newObj = myClass.AddProperty(new List<ClassHelper.CustPropertyInfo>()
-            {
-                new ClassHelper.CustPropertyInfo(typeof(string),"Name","张三"),
-                new ClassHelper.CustPropertyInfo(typeof(int),"Age",20),
-            }).AddProperty("List", new List<string>());
-
-            // act
-            Assert.Equal("张三", newObj.Name);
-            Assert.Equal(20, newObj.Age);
-            Assert.IsType<List<string>>(newObj.List);
-        }
-
-        [Fact]
-        public void Can_RemoveProperty_ReturnNewInstance()
-        {
-            // arrange
-            MyClass myClass = new MyClass()
-            {
-                MyProperty = "aa",
-                Number = 123
-            };
-
-            // act
-            object newObj = myClass.DeleteProperty("MyProperty");
-
-            // act
-            int propertyCount = newObj.GetType().GetProperties().Length;
-            Assert.Equal(1, propertyCount);
-        }
-    }
-
-    public class MyClass
-    {
-        public string MyProperty { get; set; }
-        public int Number { get; set; }
-    }
-}

+ 0 - 101
Test/Masuit.Tools.Test2222222222/Resources/download-test-file.txt

@@ -1,101 +0,0 @@
-This file has been created just for test. Please, do not remove it.
-00000000-0000-0000-0000-000000000000
-6F73BE88-F7C7-4E1A-87A7-00065CF6E89A
-5CE496D9-404C-495A-85B8-0009C5138958
-09C1297A-018E-45AB-B553-000BB8F162F9
-F177BD62-D095-419B-B7FA-000DB0D1892F
-51332D10-6790-4CC8-9C37-000ED0DB0083
-833E1983-7733-4C2D-B80D-0012C254CE81
-AB839D03-EC0C-4407-92FE-00199ACFD67B
-2E16F160-8A37-406A-AF6D-001A8CF332E8
-1D4E04D8-6087-4E60-8FE4-001B86DB3D57
-B52B65A6-013F-4A8C-80A2-001CB4F59E0E
-E0FBB808-F0F3-4812-8047-00207907B015
-58AC5AA0-E298-45F2-8785-00227DC7FB87
-E59B7950-65A8-4CE8-B6F3-00255EEEACE2
-37F172C7-5FCE-47E8-846E-00296C4FF216
-A788DE28-2BAF-48CD-A07D-00307BF4186D
-F9E01B9F-05F5-4CE3-B4B7-0031E65D6F58
-36EFC066-4B2A-4E97-B169-003CBA3C3214
-F1A45C6F-0A5A-4C1D-99DF-003E087D4A4A
-443210D7-5F78-4C89-9FE7-0043B39A92D4
-EDF5F2F1-EE31-4B47-B422-00478A6E5180
-2508BDCA-D0CB-4FD9-9E62-0049103F96E2
-1B679CE3-9F2C-4377-893B-004A97FE23E7
-351B8869-558D-4537-9B3B-004B2805869B
-26DC5ECD-E801-4F12-9BEE-004DAC6646B6
-8394074B-48EB-46C1-9C03-00503A8CC622
-A31CFF47-BDBD-4ADE-B3CB-0053D2F7CC84
-A794AC36-188B-461D-AD3D-00589AFCA911
-75549534-B55E-4DD8-A536-006224D96110
-B6982FA1-A6B3-4302-8E03-0062B05FD781
-C059086E-1142-4C29-9DA8-00645674B9D0
-4D9DBAA3-05D4-47CF-A755-00668A0EAC22
-29D6A3EF-280D-48DE-9C6A-0067F264F3EA
-86AA543B-5BF3-42D9-B91D-006AC5551E63
-FB62F575-C8AC-498D-9C99-006C2D4DAF1C
-018350D4-BDBC-4471-8101-006D0B99E6BA
-E9621011-9EE5-4205-AD5E-006D30B95FF0
-810C102C-B727-4F94-BC0D-006D74A19A02
-730486D5-2D54-4005-AE67-006E7895FA8C
-09BF434C-B4E6-414B-B4D2-00739E406221
-8F5906D7-A9D0-4594-83FE-0073A4190B6D
-3FC7EF6F-8E08-41D4-A36B-007A71ABC63D
-14E28E37-6C92-4219-BAF5-007E5BEBB6CF
-2FF432C4-DF05-45C4-A6CA-0080CC62D070
-4E98B6A2-36A2-403B-A9FB-008589C37AF9
-776A53F7-49BF-4DAD-BAEA-0086F38FB7DE
-99A66723-5D26-4013-8066-008733118814
-CF8094F2-4D35-4CE9-B577-0087E43AB7CB
-DA403697-83D8-4C35-80F7-008A44644A80
-E66600F6-93F9-4832-9AB7-008EB19E47D6
-1A9B4EFD-2B2C-4F05-A8FE-0091E8E114DB
-425D495F-A440-400E-B945-0092A8594052
-B0381374-B36F-4EF8-BC13-0093FD811712
-11FA240E-0DCE-4E22-A303-0094A1C6FEAD
-A2CA89FD-C6F8-4082-9882-0094E56F3EC7
-59820C12-2B73-4CC8-8520-0098319953BD
-2DE350E0-F84A-4810-9C29-0099607E02EB
-D1167E7C-42EC-4396-B7F9-0099A40FEC3C
-6A2774F0-9F50-4AF6-8B86-009C4CFBF5E1
-757402EC-252B-4C92-9B0B-009E5A5CEC4C
-A5623EF4-E476-45B8-8D0D-00A0FB9DEE76
-3BB1154A-D3C9-47D8-A73D-00A53992CBB9
-F37488BE-F600-491F-B462-00A559A262E6
-608B451B-4E9B-4DCD-99FE-00A5782FC9B0
-FF4F8389-5047-42EA-9218-00A610A2F67B
-3F738079-5301-4DE5-A696-00A621B8898D
-89F30700-3059-4FB1-A6F4-00A6D47CD68C
-BF29DCA4-F260-470A-B3E2-00A766FC1666
-700C29D8-C55F-474F-8636-00A827918F11
-8E91FE60-7A60-476E-A439-00A87E3FC2F5
-AF8D9AB9-47C8-4416-B844-00A889C5B3D8
-60F9F4A1-EEE4-4968-9D1F-00AF3E4DF785
-2FD09FB9-10B9-42EF-8CF6-00B2CCD7B389
-ED2C080D-9677-4AEE-854B-00B3318B72B0
-4F736871-12EA-4551-BFDF-00B69E8B2145
-24AB299B-7A45-4358-96E1-00B98A740218
-A5EFF2C8-7A19-4411-93DB-00B99D63BE66
-0B2352D9-3E61-46F8-83D5-00BAD0488768
-DD0FA0AF-4452-44AA-B201-00BF45534926
-7DBC363F-538F-4C4E-A289-00C030EC6752
-723F7306-1961-4621-AAA5-00C0EE79AE13
-139C07C4-29C2-4BD0-B076-00C15186D1E9
-4AD0A31D-6DE6-4CDA-84C2-00C241DE17B4
-3E5CFEE0-1766-49A5-AD1B-00C35AFC02E8
-1AE381CA-B4B3-459E-849F-00C5347B998D
-31C99B51-A867-4C7E-8A55-00CBCEE2F5AB
-6C1AE16E-78FF-40CA-9BE0-00D1E018A1D0
-24DE3E95-F798-435F-83D1-00D25CCDFB97
-6C7B94D0-E87E-4D4E-98E2-00D4CE4F8F58
-E22CF6FD-4F14-4300-BD39-00DA155264DC
-2D090519-6EDF-4378-9290-00DAB484432F
-5DFAA4F1-74A7-4583-B8DB-00E1A0D12E8F
-5F66986F-31AA-472B-A19E-00E1C839EE5C
-C3363650-FF03-4D88-BF5A-00E4AC4AAAF1
-735637B9-5B74-457F-BAC0-00E8C9EA4A35
-3CBCEFC2-7381-4905-9757-00E9A5246D95
-8DFE8B49-716D-4414-BC05-00EA6D24D278
-592F9F3A-C114-4467-AB7B-00EF119EA0AB
-DD2314EB-A3DF-48CF-8048-00F047D39889
-7021D545-489C-45BF-BE86-00F61719339E

+ 0 - 101
Test/Masuit.Tools.Test2222222222/Resources/download-test-file2.txt

@@ -1,101 +0,0 @@
-This file has been created just for test. Please, do not remove it.
-00000000-0000-0000-0000-000000000000
-6F73BE88-F7C7-4E1A-87A7-00065CF6E89A
-5CE496D9-404C-495A-85B8-0009C5138958
-09C1297A-018E-45AB-B553-000BB8F162F9
-F177BD62-D095-419B-B7FA-000DB0D1892F
-51332D10-6790-4CC8-9C37-000ED0DB0083
-833E1983-7733-4C2D-B80D-0012C254CE81
-AB839D03-EC0C-4407-92FE-00199ACFD67B
-2E16F160-8A37-406A-AF6D-001A8CF332E8
-1D4E04D8-6087-4E60-8FE4-001B86DB3D57
-B52B65A6-013F-4A8C-80A2-001CB4F59E0E
-E0FBB808-F0F3-4812-8047-00207907B015
-58AC5AA0-E298-45F2-8785-00227DC7FB87
-E59B7950-65A8-4CE8-B6F3-00255EEEACE2
-37F172C7-5FCE-47E8-846E-00296C4FF216
-A788DE28-2BAF-48CD-A07D-00307BF4186D
-F9E01B9F-05F5-4CE3-B4B7-0031E65D6F58
-36EFC066-4B2A-4E97-B169-003CBA3C3214
-F1A45C6F-0A5A-4C1D-99DF-003E087D4A4A
-443210D7-5F78-4C89-9FE7-0043B39A92D4
-EDF5F2F1-EE31-4B47-B422-00478A6E5180
-2508BDCA-D0CB-4FD9-9E62-0049103F96E2
-1B679CE3-9F2C-4377-893B-004A97FE23E7
-351B8869-558D-4537-9B3B-004B2805869B
-26DC5ECD-E801-4F12-9BEE-004DAC6646B6
-8394074B-48EB-46C1-9C03-00503A8CC622
-A31CFF47-BDBD-4ADE-B3CB-0053D2F7CC84
-A794AC36-188B-461D-AD3D-00589AFCA911
-75549534-B55E-4DD8-A536-006224D96110
-B6982FA1-A6B3-4302-8E03-0062B05FD781
-C059086E-1142-4C29-9DA8-00645674B9D0
-4D9DBAA3-05D4-47CF-A755-00668A0EAC22
-29D6A3EF-280D-48DE-9C6A-0067F264F3EA
-86AA543B-5BF3-42D9-B91D-006AC5551E63
-FB62F575-C8AC-498D-9C99-006C2D4DAF1C
-018350D4-BDBC-4471-8101-006D0B99E6BA
-E9621011-9EE5-4205-AD5E-006D30B95FF0
-810C102C-B727-4F94-BC0D-006D74A19A02
-730486D5-2D54-4005-AE67-006E7895FA8C
-09BF434C-B4E6-414B-B4D2-00739E406221
-8F5906D7-A9D0-4594-83FE-0073A4190B6D
-3FC7EF6F-8E08-41D4-A36B-007A71ABC63D
-14E28E37-6C92-4219-BAF5-007E5BEBB6CF
-2FF432C4-DF05-45C4-A6CA-0080CC62D070
-4E98B6A2-36A2-403B-A9FB-008589C37AF9
-776A53F7-49BF-4DAD-BAEA-0086F38FB7DE
-99A66723-5D26-4013-8066-008733118814
-CF8094F2-4D35-4CE9-B577-0087E43AB7CB
-DA403697-83D8-4C35-80F7-008A44644A80
-E66600F6-93F9-4832-9AB7-008EB19E47D6
-1A9B4EFD-2B2C-4F05-A8FE-0091E8E114DB
-425D495F-A440-400E-B945-0092A8594052
-B0381374-B36F-4EF8-BC13-0093FD811712
-11FA240E-0DCE-4E22-A303-0094A1C6FEAD
-A2CA89FD-C6F8-4082-9882-0094E56F3EC7
-59820C12-2B73-4CC8-8520-0098319953BD
-2DE350E0-F84A-4810-9C29-0099607E02EB
-D1167E7C-42EC-4396-B7F9-0099A40FEC3C
-6A2774F0-9F50-4AF6-8B86-009C4CFBF5E1
-757402EC-252B-4C92-9B0B-009E5A5CEC4C
-A5623EF4-E476-45B8-8D0D-00A0FB9DEE76
-3BB1154A-D3C9-47D8-A73D-00A53992CBB9
-F37488BE-F600-491F-B462-00A559A262E6
-608B451B-4E9B-4DCD-99FE-00A5782FC9B0
-FF4F8389-5047-42EA-9218-00A610A2F67B
-3F738079-5301-4DE5-A696-00A621B8898D
-89F30700-3059-4FB1-A6F4-00A6D47CD68C
-BF29DCA4-F260-470A-B3E2-00A766FC1666
-700C29D8-C55F-474F-8636-00A827918F11
-8E91FE60-7A60-476E-A439-00A87E3FC2F5
-AF8D9AB9-47C8-4416-B844-00A889C5B3D8
-60F9F4A1-EEE4-4968-9D1F-00AF3E4DF785
-2FD09FB9-10B9-42EF-8CF6-00B2CCD7B389
-ED2C080D-9677-4AEE-854B-00B3318B72B0
-4F736871-12EA-4551-BFDF-00B69E8B2145
-24AB299B-7A45-4358-96E1-00B98A740218
-A5EFF2C8-7A19-4411-93DB-00B99D63BE66
-0B2352D9-3E61-46F8-83D5-00BAD0488768
-DD0FA0AF-4452-44AA-B201-00BF45534926
-7DBC363F-538F-4C4E-A289-00C030EC6752
-723F7306-1961-4621-AAA5-00C0EE79AE13
-139C07C4-29C2-4BD0-B076-00C15186D1E9
-4AD0A31D-6DE6-4CDA-84C2-00C241DE17B4
-3E5CFEE0-1766-49A5-AD1B-00C35AFC02E8
-1AE381CA-B4B3-459E-849F-00C5347B998D
-31C99B51-A867-4C7E-8A55-00CBCEE2F5AB
-6C1AE16E-78FF-40CA-9BE0-00D1E018A1D0
-24DE3E95-F798-435F-83D1-00D25CCDFB97
-6C7B94D0-E87E-4D4E-98E2-00D4CE4F8F58
-E22CF6FD-4F14-4300-BD39-00DA155264DC
-2D090519-6EDF-4378-9290-00DAB484432F
-5DFAA4F1-74A7-4583-B8DB-00E1A0D12E8F
-5F66986F-31AA-472B-A19E-00E1C839EE5C
-C3363650-FF03-4D88-BF5A-00E4AC4AAAF1
-735637B9-5B74-457F-BAC0-00E8C9EA4A35
-3CBCEFC2-7381-4905-9757-00E9A5246D95
-8DFE8B49-716D-4414-BC05-00EA6D24D278
-592F9F3A-C114-4467-AB7B-00EF119EA0AB
-DD2314EB-A3DF-48CF-8048-00F047D39889
-7021D545-489C-45BF-BE86-00F61719339E

+ 0 - 44
Test/Masuit.Tools.Test2222222222/TemplateTest.cs

@@ -1,44 +0,0 @@
-using Masuit.Tools.Strings;
-using Microsoft.VisualStudio.TestTools.UnitTesting;
-using System;
-using Assert = Microsoft.VisualStudio.TestTools.UnitTesting.Assert;
-
-namespace Masuit.Tools.Test
-{
-    [TestClass]
-    public class TemplateTest
-    {
-        [TestMethod]
-        public void Render_Template()
-        {
-            var tmp = new Template("{{name}},你好!");
-            tmp.Set("name", "万金油");
-            string s = tmp.Render();
-            Assert.AreEqual("万金油,你好!", s);
-        }
-
-        [TestMethod]
-        public void Render_TemplateWithMultiVariables()
-        {
-            var tmp = new Template("{{one}},{{two}},{{three}}");
-            string s = tmp.Set("one", "1").Set("two", "2").Set("three", "3").Render();
-            Assert.AreEqual("1,2,3", s);
-        }
-
-        [TestMethod]
-        public void Render_TemplateWithUncoverVariable()
-        {
-            var tmp = new Template("{{name}},{{greet}}!");
-            tmp.Set("name", "万金油");
-            try
-            {
-                string s = tmp.Render();
-            }
-            catch (Exception e)
-            {
-                Assert.IsInstanceOfType(e, typeof(ArgumentException));
-                Assert.AreEqual("模版变量{{greet}}未被使用", e.Message);
-            }
-        }
-    }
-}

+ 0 - 23
Test/Masuit.Tools.Test2222222222/app.config

@@ -1,23 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<configuration>
-  <runtime>
-    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
-      <dependentAssembly>
-        <assemblyIdentity name="System.Runtime.CompilerServices.Unsafe" publicKeyToken="b03f5f7f11d50a3a" culture="neutral" />
-        <bindingRedirect oldVersion="0.0.0.0-4.0.6.0" newVersion="4.0.6.0" />
-      </dependentAssembly>
-      <dependentAssembly>
-        <assemblyIdentity name="System.Threading.Tasks.Extensions" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
-        <bindingRedirect oldVersion="0.0.0.0-4.2.0.1" newVersion="4.2.0.1" />
-      </dependentAssembly>
-      <dependentAssembly>
-        <assemblyIdentity name="AngleSharp" publicKeyToken="e83494dcdc6d31ea" culture="neutral" />
-        <bindingRedirect oldVersion="0.0.0.0-0.13.0.0" newVersion="0.13.0.0" />
-      </dependentAssembly>
-      <dependentAssembly>
-        <assemblyIdentity name="System.Buffers" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
-        <bindingRedirect oldVersion="0.0.0.0-4.0.3.0" newVersion="4.0.3.0" />
-      </dependentAssembly>
-    </assemblyBinding>
-  </runtime>
-</configuration>