-
Notifications
You must be signed in to change notification settings - Fork 301
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'master' into feature/array-node-workflow-parallelism
Signed-off-by: Paul Dittamo <[email protected]>
- Loading branch information
Showing
144 changed files
with
4,098 additions
and
2,488 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
name: 'Clear action cache' | ||
description: 'As suggested by GitHub to prevent low disk space: https://github.com/actions/runner-images/issues/2840#issuecomment-790492173' | ||
runs: | ||
using: 'composite' | ||
steps: | ||
- shell: bash | ||
run: | | ||
rm -rf /usr/share/dotnet | ||
rm -rf /opt/ghc | ||
rm -rf "/usr/local/share/boost" | ||
rm -rf "$AGENT_TOOLSDIRECTORY" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,14 +2,13 @@ name: Build | |
|
||
# Schedule runs to run twice a day | ||
|
||
|
||
on: | ||
push: | ||
branches: | ||
- master | ||
pull_request: | ||
schedule: | ||
- cron: '0 13 * * *' # This schedule runs at 1pm UTC every day | ||
- cron: "0 13 * * *" # This schedule runs at 1pm UTC every day | ||
|
||
env: | ||
FLYTE_SDK_LOGGING_LEVEL: 10 # debug | ||
|
@@ -42,8 +41,9 @@ jobs: | |
os: [ubuntu-latest, windows-latest, macos-latest] | ||
python-version: ${{fromJson(needs.detect-python-versions.outputs.python-versions)}} | ||
steps: | ||
- uses: insightsengineering/disk-space-reclaimer@v1 | ||
- uses: actions/checkout@v4 | ||
- name: 'Clear action cache' | ||
uses: ./.github/actions/clear-action-cache | ||
- name: Set up Python ${{ matrix.python-version }} | ||
uses: actions/setup-python@v4 | ||
with: | ||
|
@@ -79,8 +79,9 @@ jobs: | |
os: [ubuntu-latest, windows-latest, macos-latest] | ||
python-version: ${{fromJson(needs.detect-python-versions.outputs.python-versions)}} | ||
steps: | ||
- uses: insightsengineering/disk-space-reclaimer@v1 | ||
- uses: actions/checkout@v4 | ||
- name: 'Clear action cache' | ||
uses: ./.github/actions/clear-action-cache | ||
- name: Set up Python ${{ matrix.python-version }} | ||
uses: actions/setup-python@v4 | ||
with: | ||
|
@@ -116,12 +117,13 @@ jobs: | |
strategy: | ||
fail-fast: false | ||
matrix: | ||
os: [ ubuntu-latest ] | ||
os: [ubuntu-latest] | ||
python-version: ${{fromJson(needs.detect-python-versions.outputs.python-versions)}} | ||
pandas: [ "pandas<2.0.0", "pandas>=2.0.0" ] | ||
pandas: ["pandas<2.0.0", "pandas>=2.0.0"] | ||
steps: | ||
- uses: insightsengineering/disk-space-reclaimer@v1 | ||
- uses: actions/checkout@v4 | ||
- name: 'Clear action cache' | ||
uses: ./.github/actions/clear-action-cache | ||
- name: Set up Python ${{ matrix.python-version }} | ||
uses: actions/setup-python@v4 | ||
with: | ||
|
@@ -147,6 +149,41 @@ jobs: | |
fail_ci_if_error: false | ||
files: coverage.xml | ||
|
||
test-hypothesis: | ||
needs: | ||
- detect-python-versions | ||
runs-on: ${{ matrix.os }} | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
os: [ubuntu-latest] | ||
python-version: ${{fromJson(needs.detect-python-versions.outputs.python-versions)}} | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Set up Python ${{ matrix.python-version }} | ||
uses: actions/setup-python@v4 | ||
with: | ||
python-version: ${{ matrix.python-version }} | ||
- name: Cache pip | ||
uses: actions/cache@v3 | ||
with: | ||
# This path is specific to Ubuntu | ||
path: ~/.cache/pip | ||
# Look to see if there is a cache hit for the corresponding requirements files | ||
key: ${{ format('{0}-pip-{1}', runner.os, hashFiles('dev-requirements.in', 'requirements.in')) }} | ||
- name: Install dependencies | ||
run: make setup && pip freeze | ||
- name: Test with coverage | ||
env: | ||
FLYTEKIT_HYPOTHESIS_PROFILE: ci | ||
run: | | ||
make unit_test_hypothesis | ||
- name: Codecov | ||
uses: codecov/[email protected] | ||
with: | ||
fail_ci_if_error: false | ||
files: coverage.xml | ||
|
||
test-serialization: | ||
needs: | ||
- detect-python-versions | ||
|
@@ -190,7 +227,6 @@ jobs: | |
os: [ubuntu-latest] | ||
python-version: ${{fromJson(needs.detect-python-versions.outputs.python-versions)}} | ||
steps: | ||
- uses: insightsengineering/disk-space-reclaimer@v1 | ||
# As described in https://github.com/pypa/setuptools_scm/issues/414, SCM needs git history | ||
# and tags to work. | ||
- uses: actions/checkout@v4 | ||
|
@@ -257,8 +293,7 @@ jobs: | |
- flytekit-async-fsspec | ||
- flytekit-aws-athena | ||
- flytekit-aws-batch | ||
# TODO: uncomment this when the sagemaker agent is implemented: https://github.com/flyteorg/flyte/issues/4079 | ||
# - flytekit-aws-sagemaker | ||
- flytekit-aws-sagemaker | ||
- flytekit-bigquery | ||
- flytekit-dask | ||
- flytekit-data-fsspec | ||
|
@@ -315,10 +350,6 @@ jobs: | |
plugin-names: "flytekit-onnx-scikitlearn" | ||
- python-version: 3.11 | ||
plugin-names: "flytekit-onnx-tensorflow" | ||
# numba, a dependency of mlflow, doesn't support python 3.11 | ||
# https://github.com/numba/numba/issues/8304 | ||
- python-version: 3.11 | ||
plugin-names: "flytekit-mlflow" | ||
# vaex currently doesn't support python 3.11 | ||
- python-version: 3.11 | ||
plugin-names: "flytekit-vaex" | ||
|
@@ -348,9 +379,9 @@ jobs: | |
- python-version: 3.12 | ||
plugin-names: "flytekit-kf-pytorch" | ||
steps: | ||
- uses: insightsengineering/disk-space-reclaimer@v1 | ||
if: ${{ matrix.plugin-names == 'flytekit-envd' }} | ||
- uses: actions/checkout@v4 | ||
- name: 'Clear action cache' | ||
uses: ./.github/actions/clear-action-cache | ||
- name: Set up Python ${{ matrix.python-version }} | ||
uses: actions/setup-python@v4 | ||
with: | ||
|
@@ -391,10 +422,10 @@ jobs: | |
steps: | ||
- name: Fetch the code | ||
uses: actions/checkout@v4 | ||
- name: Set up Python 3.8 | ||
- name: Set up Python 3.12 | ||
uses: actions/setup-python@v4 | ||
with: | ||
python-version: 3.8 | ||
python-version: 3.12 | ||
- uses: actions/cache@v3 | ||
with: | ||
path: ~/.cache/pip | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Validating CODEOWNERS rules …
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,3 @@ | ||
# These owners will be the default owners for everything in | ||
# the repo. Unless a later match takes precedence. | ||
* @wild-endeavor @kumare3 @eapolinario @pingsutw @cosmicBboy | ||
* @wild-endeavor @kumare3 @eapolinario @pingsutw @cosmicBboy @samhita-alla |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
.. _awssagemaker_inference: | ||
|
||
##################################### | ||
AWS Sagemaker Inference API reference | ||
##################################### | ||
|
||
.. tags:: Integration, MachineLearning, AWS | ||
|
||
.. automodule:: flytekitplugins.awssagemaker_inference | ||
:no-members: | ||
:no-inherited-members: | ||
:no-special-members: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
import rich_click as click | ||
|
||
from flytekit.clis.sdk_in_container.constants import CTX_DOMAIN, CTX_PROJECT | ||
from flytekit.clis.sdk_in_container.helpers import FLYTE_REMOTE_INSTANCE_KEY, get_and_save_remote_with_click_context | ||
from flytekit.clis.sdk_in_container.utils import ( | ||
domain_option_dec, | ||
project_option_dec, | ||
) | ||
from flytekit.interfaces import cli_identifiers | ||
from flytekit.remote import FlyteRemote | ||
|
||
EXECUTION_ID = "execution_id" | ||
|
||
|
||
@click.command("relaunch", help="Relaunch a failed execution") | ||
@click.pass_context | ||
def relaunch(ctx: click.Context): | ||
""" | ||
Relaunches an execution. | ||
""" | ||
project = ctx.obj[CTX_PROJECT] | ||
domain = ctx.obj[CTX_DOMAIN] | ||
remote: FlyteRemote = ctx.obj[FLYTE_REMOTE_INSTANCE_KEY] | ||
execution_identifier = cli_identifiers.WorkflowExecutionIdentifier( | ||
project=project, domain=domain, name=ctx.obj[EXECUTION_ID] | ||
) | ||
execution_identifier_resp = remote.client.relaunch_execution(id=execution_identifier) | ||
execution_identifier = cli_identifiers.WorkflowExecutionIdentifier.promote_from_model(execution_identifier_resp) | ||
click.secho("Launched execution: {}".format(execution_identifier), fg="blue") | ||
click.echo("") | ||
|
||
|
||
@click.command("recover", help="Recover a failed execution") | ||
@click.pass_context | ||
def recover(ctx: click.Context): | ||
""" | ||
Recovers an execution. | ||
""" | ||
project = ctx.obj[CTX_PROJECT] | ||
domain = ctx.obj[CTX_DOMAIN] | ||
remote: FlyteRemote = ctx.obj[FLYTE_REMOTE_INSTANCE_KEY] | ||
execution_identifier = cli_identifiers.WorkflowExecutionIdentifier( | ||
project=project, domain=domain, name=ctx.obj[EXECUTION_ID] | ||
) | ||
execution_identifier_resp = remote.client.recover_execution(id=execution_identifier) | ||
execution_identifier = cli_identifiers.WorkflowExecutionIdentifier.promote_from_model(execution_identifier_resp) | ||
click.secho("Launched execution: {}".format(execution_identifier), fg="blue") | ||
click.echo("") | ||
|
||
|
||
execution_help = """ | ||
The execution command allows you to interact with Flyte's execution system, | ||
such as recovering/relaunching a failed execution. | ||
""" | ||
|
||
|
||
@click.group("execution", help=execution_help) | ||
@project_option_dec | ||
@domain_option_dec | ||
@click.option( | ||
EXECUTION_ID, | ||
"--execution-id", | ||
required=True, | ||
type=str, | ||
help="The execution id", | ||
) | ||
@click.pass_context | ||
def execute( | ||
ctx: click.Context, | ||
project: str, | ||
domain: str, | ||
execution_id: str, | ||
): | ||
# save remote instance in ctx.obj | ||
get_and_save_remote_with_click_context(ctx, project, domain) | ||
if ctx.obj is None: | ||
ctx.obj = {} | ||
|
||
ctx.obj.update(ctx.params) | ||
|
||
|
||
execute.add_command(recover) | ||
execute.add_command(relaunch) |
Oops, something went wrong.