Skip to content

Pipes appear to not pass on EOF on macOS runners #884

@kousu

Description

@kousu

Describe the bug

(first reported at actions/runner-images#2352)

Using yes | some_script anywhere in a workflow on macOS hangs forever. some_script will terminate but yes will keep going, blocking the rest of the workflow.

To Reproduce

I've made a minimal test case here: https://github.com/kousu/hanging-actions/. It basically just tests:

yes | head -n 7

plus collecting some context for debugging.

To reproduce, just fork my repo and watch its Actions tab. Linux (and Travis!) will pass easily, but Actions on macOS hangs until cancelled.

Expected behavior
All platforms should succeed in approximately the same time and way.

Runner Version and Platform

From my logs:

Request a runner to run this job

  • Current runner version: '2.275.1'

Operating System

  • Mac OS X
  • 10.15.7
  • 19H15

Virtual Environment

Thanks to @maxim-lobanov we know that it only happens under actions/runner, and not under https://github.com/microsoft/azure-pipelines-agent (even though azure pipelines runs the same macOS images) or when connected over VNC or ssh.

What's not working?

The symptom is that the Linux builds finish immediately while the macOS build hangs in yellow forever:

2020-12-25-043804_590x265_scrot

In fact even Travis on nearly (but not exactly the same) version of macOS works fine.

For example, consider this Actions Workflow and this this Travis script for comparison, everything finishes in about a minute except for Actions-macOS.

This should only take a moment to finish, and on Travis it does:

2020-12-25-044911_991x287_scrot

but on Actions it's at 3 minutes and counting. I've had jobs hung much longer too -- up to their 6 hour limit -- before I noticed what was going on:

2020-12-25-043814_969x287_scrot

The only way to stop the job is to cancel it. It never undeadlocks.

Job Log Output

Runner and Worker's Diagnostic Logs

I don't have access to these! If I install a runner locally and reproduce there I'll update this.

Metadata

Metadata

Assignees

No one assigned

    Labels

    Runner BugBug fix scope to the runnerbugSomething isn't working

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions