diff --git a/.editorconfig b/.editorconfig index 6cfb4760..4db563b4 100644 --- a/.editorconfig +++ b/.editorconfig @@ -6,6 +6,10 @@ root=true # All files [*] indent_style = space +# shell files +[*.{cmd,sh,bat}] +insert_final_newline = true +trim_trailing_whitespace = true # Code files [*.{cs,csx,vb,vbx}] indent_size = 4 diff --git a/BootstrapAdmin.sln b/BootstrapAdmin.sln index 637d32d9..11a708d1 100644 --- a/BootstrapAdmin.sln +++ b/BootstrapAdmin.sln @@ -96,6 +96,8 @@ Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "win", "win", "{C6F2DCA0-794 EndProject Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "linux", "linux", "{FDCFC3E3-14CF-40B2-9FE5-5BC239AAC110}" ProjectSection(SolutionItems) = preProject + deploy-admin.sh = deploy-admin.sh + deploy-client.sh = deploy-client.sh publish-admin.sh = publish-admin.sh publish-client.sh = publish-client.sh watch-run-admin.sh = watch-run-admin.sh diff --git a/Directory.Build.props b/Directory.Build.props index d54c233a..5a6cc485 100644 --- a/Directory.Build.props +++ b/Directory.Build.props @@ -1,4 +1,5 @@  + Longbow Argo Zhang(argo@163.com) @@ -11,9 +12,9 @@ - - + + diff --git a/appveyor.test.ps1 b/appveyor.test.ps1 index db415d0d..ab5353bc 100644 --- a/appveyor.test.ps1 +++ b/appveyor.test.ps1 @@ -1,28 +1,28 @@ function installDB() { write-host "init sqlserver database..." -ForegroundColor Cyan $startPath = "$($env:appveyor_build_folder)\db\SqlServer" - $sqlInstance = "(local)\SQL2014" + $sqlInstance = "(local)\SQL2017" $outFile = join-path $startPath "output.log" $sqlFile = join-path $startPath "Install.sql" $initFile = join-path $startPath "InitData.sql" sqlcmd -S "$sqlInstance" -U sa -P Password12! -i "$sqlFile" -i "$initFile" -o "$outFile" - write-host "init mysql database..." -ForegroundColor Cyan - $env:MYSQL_PWD="Password12!" - $mysql = '"C:\Program Files\MySQL\MySQL Server 5.7\bin\mysql.exe"' - $cmd = $mysql + ' -e "create database BootstrapAdmin;" -uroot' - cmd.exe /c $cmd + #write-host "init mysql database..." -ForegroundColor Cyan + #$env:MYSQL_PWD="Password12!" + #$mysql = '"C:\Program Files\MySQL\MySQL Server 5.7\bin\mysql.exe"' + #$cmd = $mysql + ' -e "create database BootstrapAdmin;" -uroot' + #cmd.exe /c $cmd - $startPath = "$($env:appveyor_build_folder)\db\MySQL" - $para = ' -hlocalhost -uroot -DBootstrapAdmin < ' - $sqlFile = join-path $startPath "Install.sql" - $cmd = $mysql + $para + $sqlFile - cmd.exe /c $cmd + #$startPath = "$($env:appveyor_build_folder)\db\MySQL" + #$para = ' -hlocalhost -uroot -DBootstrapAdmin < ' + #$sqlFile = join-path $startPath "Install.sql" + #$cmd = $mysql + $para + $sqlFile + #cmd.exe /c $cmd - $initFile = join-path $startPath "InitData.sql" - $cmd = $mysql + $para + $initFile - cmd.exe /c $cmd + #$initFile = join-path $startPath "InitData.sql" + #$cmd = $mysql + $para + $initFile + #cmd.exe /c $cmd write-host "init mongodb data..." -ForegroundColor Cyan $initFolder = "$($env:appveyor_build_folder)\db\MongoDB" @@ -38,7 +38,7 @@ function runUnitTest() { write-host "dotnet test test\UnitTest" -ForegroundColor Cyan - dotnet test test\UnitTest /p:CollectCoverage=true /p:CoverletOutputFormat=opencover /p:Include="[Bootstrap*]*" /p:ExcludeByFile="..\..\src\admin\Bootstrap.Admin\Program.cs%2c..\..\src\admin\Bootstrap.Admin\Startup.cs%2c..\..\src\admin\Bootstrap.Admin\HttpHeaderOperation.cs" /p:CoverletOutput=..\..\ + dotnet test test\UnitTest --filter "(FullyQualifiedName!~MySql) & (FullyQualifiedName!~Api.SqlServer) & (FullyQualifiedName!~Api.SQLite)" /p:CollectCoverage=true /p:CoverletOutputFormat=opencover /p:Include="[Bootstrap*]*" /p:ExcludeByFile="..\..\src\admin\Bootstrap.Admin\Program.cs%2c..\..\src\admin\Bootstrap.Admin\Startup.cs%2c..\..\src\admin\Bootstrap.Admin\HttpHeaderOperation.cs" /p:CoverletOutput=..\..\ } function coverallUnitTest() { @@ -67,6 +67,9 @@ function codecovUnitTest() { cmd.exe /c "$codecovCmd -f ""coverage.opencover.xml""" } -installDB -coverallUnitTest -codecovUnitTest \ No newline at end of file +$branch = $($env:APPVEYOR_REPO_BRANCH) +if ($branch -ne "dev") { + installDB + coverallUnitTest + codecovUnitTest +} diff --git a/appveyor.yml b/appveyor.yml index 60b317a3..17a26892 100644 --- a/appveyor.yml +++ b/appveyor.yml @@ -1,8 +1,10 @@ version: 1.0.{build} branches: only: + - release - master -image: Visual Studio 2017 + - dev +image: Visual Studio 2019 clone_depth: 1 init: - ps: git version @@ -18,16 +20,11 @@ environment: secure: +22PuAn5seq4bbCVCly8zDFuyEV3m2NjW3QuM0+2gm4c8akwicNFmv2T/ZGd0Jpd cache: C:\ProgramData\chocolatey\lib\codecov\tools services: -- mssql2014 -- mysql +- mssql2017 - mongodb install: - ps: >- - #copy my.ini into mysql folder - dotnet --version - - xcopy "$($env:appveyor_build_folder)\db\MySQL\my.ini" "C:\Program Files\MySQL\MySQL Server 5.7" /y build_script: - ps: >- .\appveyor.build.ps1 @@ -73,4 +70,4 @@ notifications: on_build_success: true on_build_failure: true - on_build_status_changed: false \ No newline at end of file + on_build_status_changed: false diff --git a/deploy-admin.sh b/deploy-admin.sh new file mode 100644 index 00000000..746df40a --- /dev/null +++ b/deploy-admin.sh @@ -0,0 +1,11 @@ +#! /bin/bash + +cd ~/BootstrapAdmin +git pull +dotnet publish src/admin/Bootstrap.Admin -c Release + +rm -f ~/BootstrapAdmin/src/admin/Bootstrap.Admin/bin/Release/netcoreapp2.2/publish/appsettings*.json +systemctl stop ba.admin +\cp -fr ~/BootstrapAdmin/src/admin/Bootstrap.Admin/bin/Release/netcoreapp2.2/publish/* /usr/local/ba/admin/ +systemctl start ba.admin +systemctl status ba.admin -l diff --git a/deploy-client.sh b/deploy-client.sh new file mode 100644 index 00000000..8c6ea577 --- /dev/null +++ b/deploy-client.sh @@ -0,0 +1,11 @@ +#! /bin/bash + +cd ~/BootstrapAdmin +git pull +dotnet publish src/client/Bootstrap.Client -c Release + +rm -f ~/BootstrapAdmin/src/client/Bootstrap.Client/bin/Release/netcoreapp2.2/publish/appsettings*.json +systemctl stop ba.client +\cp -fr ~/BootstrapAdmin/src/client/Bootstrap.Client/bin/Release/netcoreapp2.2/publish/* /usr/local/ba/client/ +systemctl start ba.client +systemctl status ba.client -l diff --git a/publish-admin.sh b/publish-admin.sh index 00fe27b0..08200ca8 100644 --- a/publish-admin.sh +++ b/publish-admin.sh @@ -1,11 +1,3 @@ #! /bin/bash -cd ~/BootstrapAdmin -git pull dotnet publish src/admin/Bootstrap.Admin -c Release - -rm -f ~/BootstrapAdmin/src/admin/Bootstrap.Admin/bin/Release/netcoreapp2.2/publish/appsettings*.json -systemctl stop ba.admin -\cp -fr ~/BootstrapAdmin/src/admin/Bootstrap.Admin/bin/Release/netcoreapp2.2/publish/* /usr/local/ba/admin/ -systemctl start ba.admin -systemctl status ba.admin diff --git a/publish-client.sh b/publish-client.sh index ad926b27..130ba9b0 100644 --- a/publish-client.sh +++ b/publish-client.sh @@ -1,11 +1,3 @@ #! /bin/bash -cd ~/BootstrapAdmin -git pull dotnet publish src/client/Bootstrap.Client -c Release - -rm -f ~/BootstrapAdmin/src/client/Bootstrap.Client/bin/Release/netcoreapp2.2/publish/appsettings*.json -systemctl stop ba.client -\cp -fr ~/BootstrapAdmin/src/client/Bootstrap.Client/bin/Release/netcoreapp2.2/publish/* /usr/local/ba/client/ -systemctl start ba.client -systemctl status ba.client diff --git a/src/admin/Bootstrap.Admin/Startup.cs b/src/admin/Bootstrap.Admin/Startup.cs index ae3f6aa5..ce258b32 100644 --- a/src/admin/Bootstrap.Admin/Startup.cs +++ b/src/admin/Bootstrap.Admin/Startup.cs @@ -14,6 +14,8 @@ using Microsoft.Extensions.Hosting; using Newtonsoft.Json; using Newtonsoft.Json.Serialization; using System; +using System.Text.Encodings.Web; +using System.Text.Unicode; namespace Bootstrap.Admin { @@ -43,7 +45,7 @@ namespace Bootstrap.Admin /// public void ConfigureServices(IServiceCollection services) { - //services.AddSingleton(HtmlEncoder.Create(UnicodeRanges.All)); + services.AddSingleton(HtmlEncoder.Create(UnicodeRanges.All)); services.Configure(options => { // This lambda determines whether user consent for non-essential cookies is needed for a given request. diff --git a/src/admin/Bootstrap.Admin/appsettings.json b/src/admin/Bootstrap.Admin/appsettings.json index 877e3667..87537e6f 100644 --- a/src/admin/Bootstrap.Admin/appsettings.json +++ b/src/admin/Bootstrap.Admin/appsettings.json @@ -87,6 +87,16 @@ "Roles": [ "Default" ], "App": "2" }, + "WeChatOptions": { + "Enabled": true, + "ClientId": "", + "ClientSecret": "", + "CallbackPath": "/signin-weixin", + "HomePath": "/Admin/Profiles", + "Scope": [ "snsapi_login" ], + "Roles": [ "Default" ], + "App": "0" + }, "SMSOptions": { "CompanyCode": "", "MD5Key": "MD5Key", diff --git a/test/Directory.Build.props b/test/Directory.Build.props new file mode 100644 index 00000000..381f48af --- /dev/null +++ b/test/Directory.Build.props @@ -0,0 +1,15 @@ + + + + true + + + + + + + + + + + diff --git a/test/UnitTest/Bootstrap.Admin/Api/HealthCheckTest.cs b/test/UnitTest/Bootstrap.Admin/Api/HealthCheckTest.cs index eeca537a..972c93ca 100644 --- a/test/UnitTest/Bootstrap.Admin/Api/HealthCheckTest.cs +++ b/test/UnitTest/Bootstrap.Admin/Api/HealthCheckTest.cs @@ -1,5 +1,4 @@ using Bootstrap.Admin.HealthChecks; -using Microsoft.AspNetCore; using Microsoft.AspNetCore.Builder; using Microsoft.AspNetCore.Diagnostics.HealthChecks; using Microsoft.AspNetCore.Hosting; @@ -8,8 +7,8 @@ using Microsoft.AspNetCore.Mvc.Testing; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Diagnostics.HealthChecks; +using Microsoft.Extensions.Hosting; using Newtonsoft.Json; -using System.IO; using System.Net.Http; using UnitTest; using Xunit; @@ -88,18 +87,19 @@ namespace Bootstrap.Admin.Api services.AddDbAdapter(); var builder = services.AddHealthChecks(); builder.AddCheck("db"); - services.AddMvcCore(); + services.AddControllers(); } // This method gets called by the runtime. Use this method to configure the HTTP request pipeline. - public void Configure(IApplicationBuilder app, IWebHostEnvironment env) + public void Configure(IApplicationBuilder app) { + app.UseRouting(); app.Use(async (context, next) => { context.User = new System.Security.Claims.ClaimsPrincipal(new System.Security.Principal.GenericIdentity("Argo")); await next(); }); - app.UseHealthChecks("/Healths", new HealthCheckOptions() + app.UseEndpoints(builder => builder.MapHealthChecks("/Healths", new HealthCheckOptions() { ResponseWriter = (context, report) => { @@ -112,8 +112,7 @@ namespace Bootstrap.Admin.Api [HealthStatus.Degraded] = StatusCodes.Status200OK, [HealthStatus.Unhealthy] = StatusCodes.Status200OK } - }); - app.UseMvcWithDefaultRoute(); + })); } } @@ -132,6 +131,6 @@ namespace Bootstrap.Admin.Api /// /// /// - protected override IWebHostBuilder CreateWebHostBuilder() => WebHost.CreateDefaultBuilder(null); + protected override IHostBuilder CreateHostBuilder() => Host.CreateDefaultBuilder().ConfigureWebHostDefaults(builder => builder.UseStartup()); } } diff --git a/test/UnitTest/Bootstrap.Admin/Controllers/SQLServer/HealthCheck.cs b/test/UnitTest/Bootstrap.Admin/Controllers/SQLServer/HealthCheck.cs index 4a5ecccf..68c721f8 100644 --- a/test/UnitTest/Bootstrap.Admin/Controllers/SQLServer/HealthCheck.cs +++ b/test/UnitTest/Bootstrap.Admin/Controllers/SQLServer/HealthCheck.cs @@ -1,6 +1,6 @@ using Xunit; -namespace Bootstrap.Admin.Controllers.SQLServer +namespace Bootstrap.Admin.Controllers.SqlServer { public class HealthCheck : ControllerTest { diff --git a/test/UnitTest/DB/UnitTest.db b/test/UnitTest/DB/UnitTest.db deleted file mode 100644 index 034052bc..00000000 Binary files a/test/UnitTest/DB/UnitTest.db and /dev/null differ diff --git a/test/UnitTest/TestHelper.cs b/test/UnitTest/TestHelper.cs index f09e6a1f..59d1eeeb 100644 --- a/test/UnitTest/TestHelper.cs +++ b/test/UnitTest/TestHelper.cs @@ -37,10 +37,6 @@ namespace UnitTest { if (providerName == DatabaseProviderType.SQLite) { - var dbPath = RetrievePath($"UnitTest{Path.DirectorySeparatorChar}DB{Path.DirectorySeparatorChar}UnitTest.db"); - var dbFile = Path.Combine(AppContext.BaseDirectory, "UnitTest.db"); - File.Copy(dbPath, dbFile, true); - builder.ConfigureAppConfiguration(app => app.AddInMemoryCollection(new KeyValuePair[] { new KeyValuePair("DB:0:Enabled", "false"), new KeyValuePair("DB:1:Enabled", "true") diff --git a/test/UnitTest/UnitTest.csproj b/test/UnitTest/UnitTest.csproj index 1503e27f..05a83bf1 100644 --- a/test/UnitTest/UnitTest.csproj +++ b/test/UnitTest/UnitTest.csproj @@ -9,7 +9,11 @@ all - runtime; build; native; contentfiles; analyzers + runtime; build; native; contentfiles; analyzers; buildtransitive + + + all + runtime; build; native; contentfiles; analyzers; buildtransitive diff --git a/test/UnitTest/appsettings.json b/test/UnitTest/appsettings.json index f00519b3..084fb0fd 100644 --- a/test/UnitTest/appsettings.json +++ b/test/UnitTest/appsettings.json @@ -24,7 +24,7 @@ "Enabled": false, "ProviderName": "Sqlite", "ConnectionStrings": { - "ba": "Data Source=UnitTest.db;" + "ba": "Data Source=BootstrapAdmin.db;" } }, { diff --git a/watch-run-admin.cmd b/watch-run-admin.cmd index 782c6476..571158d4 100644 --- a/watch-run-admin.cmd +++ b/watch-run-admin.cmd @@ -1,3 +1,3 @@ @echo off -dotnet watch --project ./src/admin/Bootstrap.Admin run \ No newline at end of file +dotnet watch --project ./src/admin/Bootstrap.Admin run diff --git a/watch-run-admin.sh b/watch-run-admin.sh index fa427aef..f6aa9f20 100644 --- a/watch-run-admin.sh +++ b/watch-run-admin.sh @@ -1,3 +1,3 @@ #! /bin/bash -dotnet watch --project ./src/admin/Bootstrap.Admin run \ No newline at end of file +dotnet watch --project ./src/admin/Bootstrap.Admin run diff --git a/watch-run-client.cmd b/watch-run-client.cmd index ce983821..058db3e7 100644 --- a/watch-run-client.cmd +++ b/watch-run-client.cmd @@ -1,3 +1,3 @@ @echo off -dotnet watch --project ./src/client/Bootstrap.Client run \ No newline at end of file +dotnet watch --project ./src/client/Bootstrap.Client run diff --git a/watch-run-client.sh b/watch-run-client.sh index 87a84eec..0457f727 100644 --- a/watch-run-client.sh +++ b/watch-run-client.sh @@ -1,3 +1,3 @@ #! /bin/bash -dotnet watch --project ./src/client/Bootstrap.Client run \ No newline at end of file +dotnet watch --project ./src/client/Bootstrap.Client run