-
Notifications
You must be signed in to change notification settings - Fork 176
/
circle.ex
82 lines (71 loc) · 2.23 KB
/
circle.ex
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
defmodule ExCoveralls.Circle do
@moduledoc """
Handles circle-ci integration with coveralls.
"""
alias ExCoveralls.Poster
def execute(stats, options) do
json = generate_json(stats, Enum.into(options, %{}))
if options[:verbose] do
IO.puts json
end
Poster.execute(json)
end
def generate_json(stats, options \\ %{})
def generate_json(stats, options) do
Jason.encode!(%{
repo_token: get_repo_token(),
service_name: "circle-ci",
service_number: get_number(),
service_job_id: get_job_id(),
service_pull_request: get_pull_request(),
source_files: stats,
git: generate_git_info(),
parallel: options[:parallel],
flag_name: options[:flagname]
})
end
defp generate_git_info do
%{head: %{
committer_name: get_committer(),
message: get_message!(),
id: get_sha()
},
branch: get_branch()
}
end
defp get_pull_request do
case Regex.run(~r/(\d+)$/, System.get_env("CI_PULL_REQUEST") || "") do
[_, id] -> id
_ -> nil
end
end
defp get_message! do
case System.cmd("git", ["log", "-1", "--pretty=format:%s"]) do
{message, _} -> message
_ -> "[no commit message]"
end
end
defp get_committer do
System.get_env("CIRCLE_USERNAME")
end
defp get_sha do
System.get_env("CIRCLE_SHA1")
end
defp get_branch do
System.get_env("CIRCLE_BRANCH")
end
defp get_job_id do
# When using workflows, each job has a separate `CIRCLE_BUILD_NUM`, so this needs to be used as the Job ID and not
# the Job Number. If the job is configured with `parallelism` greater than one, then the `CIRCLE_NODE_INDEX` is
# used to differentiate between separate containers running the same job.
"#{System.get_env("CIRCLE_BUILD_NUM")}-#{System.get_env("CIRCLE_NODE_INDEX")}"
end
defp get_number do
# `CIRCLE_WORKFLOW_WORKSPACE_ID` is the same when "Rerun failed job" is done while `CIRCLE_WORKFLOW_ID` changes, so
# use `CIRCLE_WORKFLOW_WORKSPACE_ID` so that the results from the original and rerun are combined
System.get_env("CIRCLE_WORKFLOW_WORKSPACE_ID") || System.get_env("CIRCLE_BUILD_NUM")
end
defp get_repo_token do
System.get_env("COVERALLS_REPO_TOKEN")
end
end