Skip to content

Commit

Permalink
Set context when creating kind cluster
Browse files Browse the repository at this point in the history
  • Loading branch information
IrvingMg committed Nov 21, 2024
1 parent 7d19eca commit 6693e4c
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 39 deletions.
40 changes: 2 additions & 38 deletions src/xpk/commands/batch.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,10 +21,8 @@
from ..core.job_template import create_job_template_instance
from ..core.app_profile import create_app_profile_instance
from ..core.app_profile import APP_PROFILE_TEMPLATE_DEFAULT_NAME
from ..core.commands import (
run_command_for_value,
run_command_with_updates,
)
from ..core.commands import run_command_for_value
from .kind import set_local_cluster_command


def batch(args: Namespace) -> None:
Expand Down Expand Up @@ -61,37 +59,3 @@ def submit_job(args: Namespace) -> None:
if return_code != 0:
xpk_print(f'Running batch job returned ERROR {return_code}')
xpk_exit(return_code)


def set_local_cluster_command(args) -> int:
"""Run local cluster configuration command to set the kubectl config.
Args:
args: user provided arguments for running the command.
Returns:
0 if successful and 1 otherwise.
"""
if not args.cluster:
command = 'kubectl config current-context'
return_code, current_context = run_command_for_value(
command, 'get current-context', args
)
xpk_print(
'No local cluster name specified. Using current-context'
f' `{current_context.strip()}`'
)
return return_code

command = (
f'kubectl config use-context kind-{args.cluster} --namespace=default'
)
task = f'switch to cluster {args.cluster}'
return_code = run_command_with_updates(
command,
task,
args,
)
if return_code != 0:
xpk_print(f'{task} returned ERROR {return_code}')
return return_code
2 changes: 1 addition & 1 deletion src/xpk/commands/job.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@
run_command_with_updates,
)
from .cluster import set_cluster_command
from .batch import set_local_cluster_command
from .kind import set_local_cluster_command


def job_list(args) -> None:
Expand Down
38 changes: 38 additions & 0 deletions src/xpk/commands/kind.py
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,10 @@ def cluster_create(args) -> None:
if create_cluster_command_code != 0:
xpk_exit(create_cluster_command_code)

set_cluster_command_code = set_local_cluster_command(args)
if set_cluster_command_code != 0:
xpk_exit(set_cluster_command_code)

xpk_print(
'Enabling the jobset API on our cluster, to be deprecated when Jobset is'
' globally available'
Expand Down Expand Up @@ -213,3 +217,37 @@ def get_all_local_clusters_programmatic(args) -> tuple[list[str], int]:
return [], return_code

return raw_cluster_output.splitlines(), 0


def set_local_cluster_command(args) -> int:
"""Run local cluster configuration command to set the kubectl config.
Args:
args: user provided arguments for running the command.
Returns:
0 if successful and 1 otherwise.
"""
if not args.cluster:
command = 'kubectl config current-context'
return_code, current_context = run_command_for_value(
command, 'get current-context', args
)
xpk_print(
'No local cluster name specified. Using current-context'
f' `{current_context.strip()}`'
)
return return_code

command = (
f'kubectl config use-context kind-{args.cluster} --namespace=default'
)
task = f'switch to cluster {args.cluster}'
return_code = run_command_with_updates(
command,
task,
args,
)
if return_code != 0:
xpk_print(f'{task} returned ERROR {return_code}')
return return_code

0 comments on commit 6693e4c

Please sign in to comment.