-
Notifications
You must be signed in to change notification settings - Fork 41
/
build.fsx
152 lines (129 loc) · 5.38 KB
/
build.fsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
#r @"packages/build/FAKE/tools/FakeLib.dll"
open System
open Fake
Environment.CurrentDirectory <- __SOURCE_DIRECTORY__
let configuration = environVarOrDefault "Configuration" "Release"
let release = IO.File.ReadAllLines "RELEASE_NOTES.md" |> ReleaseNotesHelper.parseReleaseNotes
let description = "A simple, functional HTTP client library for F#"
let tags = "http fsharp client functional"
let authors = "Henrik Feldt"
let owners = "Henrik Feldt"
let projectUrl = "https://github.com/haf/Http.fs"
let iconUrl = "https://raw.githubusercontent.com/haf/Http.fs/releases/v4.x/docs/files/img/logo.png"
let licenceUrl = "https://github.com/haf/Http.fs/blob/master/Licence/License.md"
let copyright = sprintf "Copyright \169 %i" DateTime.Now.Year
Target "Clean" (fun _ -> !!"./**/bin/" ++ "./**/obj/" |> CleanDirs)
open AssemblyInfoFile
Target "AssemblyInfo" (fun _ ->
[ "HttpFs"
"HttpFs.UnitTests"
"HttpFs.IntegrationTests"
]
|> List.iter (fun product ->
[ Attribute.Title product
Attribute.Product product
Attribute.Copyright copyright
Attribute.Description description
Attribute.Version release.AssemblyVersion
Attribute.FileVersion release.AssemblyVersion
] |> CreateFSharpAssemblyInfo (product+"/AssemblyInfo.fs")
)
)
Target "PaketFiles" (fun _ ->
FileHelper.ReplaceInFiles ["namespace Logary.Facade","namespace HttpFs.Logging"]
["paket-files/logary/logary/src/Logary.Facade/Facade.fs"]
)
Target "ProjectVersion" (fun _ ->
[
"HttpFs/HttpFs.fsproj"
]
|> List.iter (fun file ->
XMLHelper.XmlPoke file "Project/PropertyGroup/Version/text()" release.NugetVersion)
)
let build project framework =
DotNetCli.Build (fun p ->
{ p with
Configuration = configuration
Framework = framework
Project = project
})
Target "BuildTest" (fun _ ->
build "HttpFs.UnitTests/HttpFs.UnitTests.fsproj" "netcoreapp2.0"
build "HttpFs.UnitTests/HttpFs.UnitTests.fsproj" "net471"
build "HttpFs.IntegrationTests/HttpFs.IntegrationTests.fsproj" "netcoreapp2.0"
build "HttpFs.IntegrationTests/HttpFs.IntegrationTests.fsproj" "net471"
)
Target "RunTest" (fun _ ->
DotNetCli.RunCommand id ("HttpFs.UnitTests/bin/"+configuration+"/netcoreapp2.0/HttpFs.UnitTests.dll --summary --sequenced")
//Shell.Exec ("HttpFs.UnitTests/bin/"+configuration+"/net471/HttpFs.UnitTests.exe","--summary --sequenced")
//|> fun r -> if r<>0 then failwith "HttpFs.UnitTests.exe failed"
DotNetCli.RunCommand id ("HttpFs.IntegrationTests/bin/"+configuration+"/netcoreapp2.0/HttpFs.IntegrationTests.dll --summary --sequenced")
//Shell.Exec ("HttpFs.IntegrationTests/bin/"+configuration+"/net471/HttpFs.IntegrationTests.exe","--summary --sequenced")
//|> fun r -> if r<>0 then failwith "HttpFs.IntegrationTests.exe failed"
)
Target "Pack" (fun _ ->
let packParameters name =
[
"--no-build"
"--no-restore"
sprintf "/p:Title=\"%s\"" name
"/p:PackageVersion=" + release.NugetVersion
sprintf "/p:Authors=\"%s\"" authors
sprintf "/p:Owners=\"%s\"" owners
"/p:PackageRequireLicenseAcceptance=false"
sprintf "/p:Description=\"%s\"" (description.Replace(",",""))
sprintf "/p:PackageReleaseNotes=\"%O\"" ((toLines release.Notes).Replace(",",""))
sprintf "/p:Copyright=\"%s\"" copyright
sprintf "/p:PackageTags=\"%s\"" tags
sprintf "/p:PackageProjectUrl=\"%s\"" projectUrl
sprintf "/p:PackageIconUrl=\"%s\"" iconUrl
sprintf "/p:PackageLicenseUrl=\"%s\"" licenceUrl
] |> String.concat " "
DotNetCli.RunCommand id
("pack HttpFs/HttpFs.fsproj -c "+configuration + " -o ../bin " + (packParameters "Http.fs"))
)
let envReq key =
let value = Environment.GetEnvironmentVariable key
if String.IsNullOrWhiteSpace value then failwith "GITHUB_TOKEN env var is missing."
value
Target "GuardEnv" (fun _ ->
ignore (envReq "GITHUB_TOKEN")
ignore (envReq "NUGET_KEY"))
Target "Push" (fun _ ->
Paket.Push (fun p -> { p with WorkingDir = "bin"
ApiKey = envReq "NUGET_KEY"
}))
#load "paket-files/build/fsharp/FAKE/modules/Octokit/Octokit.fsx"
Target "Release" (fun _ ->
let gitOwner = "haf"
let gitName = "Http.fs"
let gitOwnerName = gitOwner + "/" + gitName
let remote =
Git.CommandHelper.getGitResult "" "remote -v"
|> Seq.tryFind (fun s -> s.EndsWith "(push)" && s.Contains gitOwnerName)
|> function None -> ("[email protected]:"+gitOwnerName) | Some s -> s.Split().[0]
Git.Staging.StageAll ""
Git.Commit.Commit "" (sprintf "Bump version to %s" release.NugetVersion)
Git.Branches.pushBranch "" remote (Git.Information.getBranchName "")
let tag = sprintf "v%O" release.SemVer
Git.Branches.tag "" tag
Git.Branches.pushTag "" remote tag
Octokit.createClientWithToken (Environment.GetEnvironmentVariable "GITHUB_TOKEN")
|> Octokit.createDraft gitOwner gitName tag (Option.isSome release.SemVer.PreRelease) release.Notes
|> Octokit.releaseDraft
|> Async.RunSynchronously
)
"GuardEnv" ==> "Push"
"GuardEnv" ==> "Release"
Target "All" ignore
"Clean"
==> "AssemblyInfo"
==> "PaketFiles"
==> "ProjectVersion"
==> "BuildTest"
==> "RunTest"
==> "Pack"
==> "All"
==> "Push"
==> "Release"
RunTargetOrDefault "All"