mirror of
https://github.com/actions/runner.git
synced 2026-01-07 02:27:23 +08:00
Compare commits
5 Commits
h10s-assoc
...
releases/m
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
8c938489a6 | ||
|
|
ef4f6aad67 | ||
|
|
f472532284 | ||
|
|
2d43c04c22 | ||
|
|
a003b1ca69 |
@@ -11,10 +11,12 @@
|
||||
- Add help info for '--labels' config option (#472)
|
||||
- Sps/token migration fix, job.status/steps.outcome/steps.conclusion case match with GitHub check suites conclusion. (#462)
|
||||
- Docker build using -f instead of implied default (#471)
|
||||
- Fix configure as service with runner name has space. (#474)
|
||||
## Misc
|
||||
- Make release notes code blocks copy-paste-able (#430)
|
||||
- Fix spelling of RHEL and CentOS. (#436)
|
||||
- Add CodeQL Analysis workflow (#459)
|
||||
- Use an env var to point to an Actions Service dev instance (#468)
|
||||
|
||||
## Windows x64
|
||||
We recommend configuring the runner in a root folder of the Windows drive (e.g. "C:\actions-runner"). This will help avoid issues related to service identity folder permissions and long file path restrictions on Windows.
|
||||
|
||||
@@ -1 +1 @@
|
||||
<Update to ./src/runnerversion when creating release>
|
||||
2.262.1
|
||||
|
||||
@@ -81,7 +81,7 @@ fi
|
||||
|
||||
export RUNNER_TOKEN=$(curl -s -X POST ${base_api_url}/${orgs_or_repos}/${runner_scope}/actions/runners/registration-token -H "accept: application/vnd.github.everest-preview+json" -H "authorization: token ${RUNNER_CFG_PAT}" | jq -r '.token')
|
||||
|
||||
if [ "null" == "$RUNNER_TOKEN" -o -z "$RUNNER_TOKEN" ]; then fatal "Failed to get a token"; fi
|
||||
if [ -z "$RUNNER_TOKEN" ]; then fatal "Failed to get a token"; fi
|
||||
|
||||
#---------------------------------------
|
||||
# Download latest released and extract
|
||||
|
||||
@@ -82,7 +82,7 @@ namespace GitHub.Runner.Plugins.Repository.v1_0
|
||||
executionContext.Output($"Syncing repository: {repoFullName}");
|
||||
|
||||
// Repository URL
|
||||
var githubUrl = executionContext.GetGitHubContext("server_url");
|
||||
var githubUrl = executionContext.GetGitHubContext("url");
|
||||
var githubUri = new Uri(!string.IsNullOrEmpty(githubUrl) ? githubUrl : "https://github.com");
|
||||
var portInfo = githubUri.IsDefaultPort ? string.Empty : $":{githubUri.Port}";
|
||||
Uri repositoryUrl = new Uri($"{githubUri.Scheme}://{githubUri.Host}{portInfo}/{repoFullName}");
|
||||
|
||||
@@ -150,8 +150,7 @@ namespace GitHub.Runner.Worker
|
||||
containerSetupSteps.Add(new JobExtensionRunner(runAsync: this.PullActionContainerAsync,
|
||||
condition: $"{PipelineTemplateConstants.Success}()",
|
||||
displayName: $"Pull {imageToPull.Key}",
|
||||
data: new ContainerSetupInfo(imageToPull.Value, imageToPull.Key),
|
||||
repositoryRef: null));
|
||||
data: new ContainerSetupInfo(imageToPull.Value, imageToPull.Key)));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -164,8 +163,7 @@ namespace GitHub.Runner.Worker
|
||||
containerSetupSteps.Add(new JobExtensionRunner(runAsync: this.BuildActionContainerAsync,
|
||||
condition: $"{PipelineTemplateConstants.Success}()",
|
||||
displayName: $"Build {setupInfo.ActionRepository}",
|
||||
data: new ContainerSetupInfo(imageToBuild.Value, setupInfo.Dockerfile, setupInfo.WorkingDirectory),
|
||||
repositoryRef: setupInfo.RepositoryRef));
|
||||
data: new ContainerSetupInfo(imageToBuild.Value, setupInfo.Dockerfile, setupInfo.WorkingDirectory)));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -778,7 +776,6 @@ namespace GitHub.Runner.Worker
|
||||
}
|
||||
|
||||
var setupInfo = new ActionContainer();
|
||||
setupInfo.RepositoryRef = repositoryReference;
|
||||
string destDirectory = Path.Combine(HostContext.GetDirectory(WellKnownDirectory.Actions), repositoryReference.Name.Replace(Path.AltDirectorySeparatorChar, Path.DirectorySeparatorChar), repositoryReference.Ref);
|
||||
string actionEntryDirectory = destDirectory;
|
||||
string dockerFileRelativePath = repositoryReference.Name;
|
||||
@@ -1025,6 +1022,5 @@ namespace GitHub.Runner.Worker
|
||||
public string Dockerfile { get; set; }
|
||||
public string WorkingDirectory { get; set; }
|
||||
public string ActionRepository { get; set; }
|
||||
public Pipelines.RepositoryPathReference RepositoryRef { get; set; }
|
||||
}
|
||||
}
|
||||
|
||||
@@ -46,8 +46,7 @@ namespace GitHub.Runner.Worker
|
||||
var postJobStep = new JobExtensionRunner(runAsync: this.StopContainersAsync,
|
||||
condition: $"{PipelineTemplateConstants.Always}()",
|
||||
displayName: "Stop containers",
|
||||
data: data,
|
||||
repositoryRef: null);
|
||||
data: data);
|
||||
|
||||
executionContext.Debug($"Register post job cleanup for stopping/deleting containers.");
|
||||
executionContext.RegisterPostJobStep(postJobStep);
|
||||
|
||||
@@ -260,9 +260,7 @@ namespace GitHub.Runner.Worker
|
||||
return;
|
||||
}
|
||||
|
||||
string refName = step.GetRefName();
|
||||
|
||||
step.ExecutionContext = Root.CreatePostChild(step.DisplayName, refName, IntraActionState);
|
||||
step.ExecutionContext = Root.CreatePostChild(step.DisplayName, IntraActionState);
|
||||
Root.PostJobSteps.Push(step);
|
||||
}
|
||||
|
||||
@@ -270,12 +268,6 @@ namespace GitHub.Runner.Worker
|
||||
{
|
||||
Trace.Entering();
|
||||
|
||||
// TODO: Null out old, non-json refNames only if a FF is set.
|
||||
if (refName != null && !refName.StartsWith("{"))
|
||||
{
|
||||
refName = null;
|
||||
}
|
||||
|
||||
var child = new ExecutionContext();
|
||||
child.Initialize(HostContext);
|
||||
child.ScopeName = scopeName;
|
||||
@@ -860,7 +852,7 @@ namespace GitHub.Runner.Worker
|
||||
{
|
||||
Interlocked.Add(ref _totalThrottlingDelayInMilliseconds, Convert.ToInt64(data.Delay.TotalMilliseconds));
|
||||
|
||||
if (!_throttlingReported &&
|
||||
if (!_throttlingReported &&
|
||||
_totalThrottlingDelayInMilliseconds > _throttlingDelayReportThreshold)
|
||||
{
|
||||
this.Warning(string.Format("The job is currently being throttled by the server. You may experience delays in console line output, job status reporting, and action log uploads."));
|
||||
@@ -869,7 +861,7 @@ namespace GitHub.Runner.Worker
|
||||
}
|
||||
}
|
||||
|
||||
private IExecutionContext CreatePostChild(string displayName, string refName, Dictionary<string, string> intraActionState)
|
||||
private IExecutionContext CreatePostChild(string displayName, Dictionary<string, string> intraActionState)
|
||||
{
|
||||
if (!_expandedForPostJob)
|
||||
{
|
||||
@@ -879,9 +871,7 @@ namespace GitHub.Runner.Worker
|
||||
}
|
||||
|
||||
var newGuid = Guid.NewGuid();
|
||||
|
||||
// TODO: Check feature flag here, conditionally set refName to newGuid.ToString("N").
|
||||
return CreateChild(newGuid, displayName, refName, null, null, intraActionState, _childTimelineRecordOrder - Root.PostJobSteps.Count);
|
||||
return CreateChild(newGuid, displayName, newGuid.ToString("N"), null, null, intraActionState, _childTimelineRecordOrder - Root.PostJobSteps.Count);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -22,8 +22,8 @@ namespace GitHub.Runner.Worker
|
||||
"repository_owner",
|
||||
"run_id",
|
||||
"run_number",
|
||||
"server_url",
|
||||
"sha",
|
||||
"url",
|
||||
"workflow",
|
||||
"workspace",
|
||||
};
|
||||
|
||||
@@ -1,31 +0,0 @@
|
||||
using Newtonsoft.Json;
|
||||
|
||||
namespace GitHub.Runner.Worker
|
||||
{
|
||||
public static class IStepExtensions
|
||||
{
|
||||
public static string GetRefName(this IStep step, string defaultRefName = null)
|
||||
{
|
||||
// TODO: Really check a feature flag.
|
||||
if (s_featureFlagEnabled)
|
||||
{
|
||||
if (step is JobExtensionRunner extensionRunner && extensionRunner.RepositoryRef != null)
|
||||
{
|
||||
return JsonConvert.SerializeObject(extensionRunner.RepositoryRef);
|
||||
}
|
||||
|
||||
if (step is IActionRunner actionRunner && actionRunner.Action?.Reference != null)
|
||||
{
|
||||
return JsonConvert.SerializeObject(actionRunner.Action.Reference);
|
||||
}
|
||||
|
||||
// RefName should always be valid json or null.
|
||||
return null;
|
||||
}
|
||||
|
||||
return defaultRefName;
|
||||
}
|
||||
|
||||
private static bool s_featureFlagEnabled = true;
|
||||
}
|
||||
}
|
||||
@@ -131,13 +131,12 @@ namespace GitHub.Runner.Worker
|
||||
// Temporary hack for GHES alpha
|
||||
var configurationStore = HostContext.GetService<IConfigurationStore>();
|
||||
var runnerSettings = configurationStore.GetSettings();
|
||||
if (string.IsNullOrEmpty(context.GetGitHubContext("server_url")) && !runnerSettings.IsHostedServer && !string.IsNullOrEmpty(runnerSettings.GitHubUrl))
|
||||
if (string.IsNullOrEmpty(context.GetGitHubContext("url")) && !runnerSettings.IsHostedServer && !string.IsNullOrEmpty(runnerSettings.GitHubUrl))
|
||||
{
|
||||
var url = new Uri(runnerSettings.GitHubUrl);
|
||||
var portInfo = url.IsDefaultPort ? string.Empty : $":{url.Port.ToString(CultureInfo.InvariantCulture)}";
|
||||
context.SetGitHubContext("server_url", $"{url.Scheme}://{url.Host}{portInfo}");
|
||||
context.SetGitHubContext("url", $"{url.Scheme}://{url.Host}{portInfo}");
|
||||
context.SetGitHubContext("api_url", $"{url.Scheme}://{url.Host}{portInfo}/api/v3");
|
||||
context.SetGitHubContext("graphql_url", $"{url.Scheme}://{url.Host}{portInfo}/api/graphql");
|
||||
}
|
||||
|
||||
// Evaluate the job-level environment variables
|
||||
@@ -213,10 +212,9 @@ namespace GitHub.Runner.Worker
|
||||
containers.AddRange(jobContext.ServiceContainers);
|
||||
|
||||
preJobSteps.Add(new JobExtensionRunner(runAsync: containerProvider.StartContainersAsync,
|
||||
condition: $"{PipelineTemplateConstants.Success}()",
|
||||
displayName: "Initialize containers",
|
||||
data: (object)containers,
|
||||
repositoryRef: null));
|
||||
condition: $"{PipelineTemplateConstants.Success}()",
|
||||
displayName: "Initialize containers",
|
||||
data: (object)containers));
|
||||
}
|
||||
|
||||
// Add action steps
|
||||
@@ -261,19 +259,18 @@ namespace GitHub.Runner.Worker
|
||||
// Create execution context for pre-job steps
|
||||
foreach (var step in preJobSteps)
|
||||
{
|
||||
if (step is JobExtensionRunner extensionStep)
|
||||
if (step is JobExtensionRunner)
|
||||
{
|
||||
ArgUtil.NotNull(extensionStep, step.DisplayName);
|
||||
JobExtensionRunner extensionStep = step as JobExtensionRunner;
|
||||
ArgUtil.NotNull(extensionStep, extensionStep.DisplayName);
|
||||
Guid stepId = Guid.NewGuid();
|
||||
var refName = step.GetRefName(defaultRefName: null);
|
||||
extensionStep.ExecutionContext = jobContext.CreateChild(stepId, extensionStep.DisplayName, refName, null, stepId.ToString("N"));
|
||||
extensionStep.ExecutionContext = jobContext.CreateChild(stepId, extensionStep.DisplayName, null, null, stepId.ToString("N"));
|
||||
}
|
||||
else if (step is IActionRunner actionStep)
|
||||
{
|
||||
ArgUtil.NotNull(actionStep, step.DisplayName);
|
||||
Guid stepId = Guid.NewGuid();
|
||||
var refName = step.GetRefName(defaultRefName: stepId.ToString("N"));
|
||||
actionStep.ExecutionContext = jobContext.CreateChild(stepId, actionStep.DisplayName, refName, null, null, intraActionStates[actionStep.Action.Id]);
|
||||
actionStep.ExecutionContext = jobContext.CreateChild(stepId, actionStep.DisplayName, stepId.ToString("N"), null, null, intraActionStates[actionStep.Action.Id]);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -284,8 +281,7 @@ namespace GitHub.Runner.Worker
|
||||
{
|
||||
ArgUtil.NotNull(actionStep, step.DisplayName);
|
||||
intraActionStates.TryGetValue(actionStep.Action.Id, out var intraActionState);
|
||||
var refName = step.GetRefName(defaultRefName: actionStep.Action.Name);
|
||||
actionStep.ExecutionContext = jobContext.CreateChild(actionStep.Action.Id, actionStep.DisplayName, refName, actionStep.Action.ScopeName, actionStep.Action.ContextName, intraActionState);
|
||||
actionStep.ExecutionContext = jobContext.CreateChild(actionStep.Action.Id, actionStep.DisplayName, actionStep.Action.Name, actionStep.Action.ScopeName, actionStep.Action.ContextName, intraActionState);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
using System;
|
||||
using System.Threading.Tasks;
|
||||
using GitHub.DistributedTask.Expressions2;
|
||||
using GitHub.DistributedTask.ObjectTemplating.Tokens;
|
||||
using GitHub.DistributedTask.Pipelines;
|
||||
|
||||
namespace GitHub.Runner.Worker
|
||||
{
|
||||
@@ -9,26 +9,22 @@ namespace GitHub.Runner.Worker
|
||||
{
|
||||
private readonly object _data;
|
||||
private readonly Func<IExecutionContext, object, Task> _runAsync;
|
||||
private readonly RepositoryPathReference _repositoryRef;
|
||||
|
||||
public JobExtensionRunner(
|
||||
Func<IExecutionContext, object, Task> runAsync,
|
||||
string condition,
|
||||
string displayName,
|
||||
object data,
|
||||
RepositoryPathReference repositoryRef)
|
||||
object data)
|
||||
{
|
||||
_runAsync = runAsync;
|
||||
Condition = condition;
|
||||
DisplayName = displayName;
|
||||
_data = data;
|
||||
_repositoryRef = repositoryRef;
|
||||
}
|
||||
|
||||
public string Condition { get; set; }
|
||||
public TemplateToken ContinueOnError => new BooleanToken(null, null, null, false);
|
||||
public string DisplayName { get; set; }
|
||||
public RepositoryPathReference RepositoryRef => _repositoryRef;
|
||||
public IExecutionContext ExecutionContext { get; set; }
|
||||
public TemplateToken Timeout => new NumberToken(null, null, null, 0);
|
||||
public object Data => _data;
|
||||
|
||||
@@ -22,7 +22,7 @@ namespace GitHub.DistributedTask.Pipelines
|
||||
[DataContract]
|
||||
[KnownType(typeof(ContainerRegistryReference))]
|
||||
[KnownType(typeof(RepositoryPathReference))]
|
||||
[KnownType(typeof(ScriptReference))]
|
||||
[KnownType(typeof(ScriptReference))]
|
||||
[JsonConverter(typeof(ActionStepDefinitionReferenceConverter))]
|
||||
[EditorBrowsable(EditorBrowsableState.Never)]
|
||||
public abstract class ActionStepDefinitionReference
|
||||
|
||||
@@ -176,7 +176,7 @@ namespace GitHub.Runner.Common.Tests.Worker
|
||||
jobExtension.Initialize(hc);
|
||||
|
||||
_actionManager.Setup(x => x.PrepareActionsAsync(It.IsAny<IExecutionContext>(), It.IsAny<IEnumerable<Pipelines.JobStep>>()))
|
||||
.Returns(Task.FromResult(new PrepareResult(new List<JobExtensionRunner>() { new JobExtensionRunner(null, "", "prepare1", null, null), new JobExtensionRunner(null, "", "prepare2", null, null) }, new Dictionary<Guid, IActionRunner>())));
|
||||
.Returns(Task.FromResult(new PrepareResult(new List<JobExtensionRunner>() { new JobExtensionRunner(null, "", "prepare1", null), new JobExtensionRunner(null, "", "prepare2", null) }, new Dictionary<Guid, IActionRunner>())));
|
||||
|
||||
List<IStep> result = await jobExtension.InitializeJob(_jobEc, _message);
|
||||
|
||||
|
||||
@@ -1 +1 @@
|
||||
2.262.0
|
||||
2.262.1
|
||||
|
||||
Reference in New Issue
Block a user