Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Fix][kubectl-plugin] Fix no context nil error SIGSEGV in tests #2892

Conversation

MortalHappiness
Copy link
Member

@MortalHappiness MortalHappiness commented Feb 4, 2025

Why are these changes needed?

Replace assert.Equal(t, tc.expectError, err.Error()) with assert.Error(t, err, tc.expectError) because if err is nil, then err.Error() will cause SIGSEGV.

Related issue number

N/A

Checks

  • I've made sure the tests are passing.
  • Testing Strategy
    • Unit tests
    • Manual tests
    • This PR is not tested :(

Signed-off-by: Chi-Sheng Liu <chishengliu@chishengliu.com>
@kevin85421 kevin85421 merged commit c8d34f4 into ray-project:master Feb 4, 2025
20 checks passed
@MortalHappiness MortalHappiness mentioned this pull request Feb 5, 2025
4 tasks
@MortalHappiness
Copy link
Member Author

@truongminhdien Please don't spam comments.

andrewsykim added a commit that referenced this pull request Feb 5, 2025
* [RayService] More envtests that follow the most common scenario in the RayService code path (#2880)

Signed-off-by: Rueian <rueiancsie@gmail.com>

* [RayService] Remove outdated env tests (#2886)

Signed-off-by: kaihsun <kaihsun@anyscale.com>

* [RayService] Refactor envtests (#2888)

* [docs][ray-operator] fix typo in Golang version (#2893)

Project uses Golang 1.22 not 1.20.

Signed-off-by: David Xia <david@davidxia.com>

* [Fix][kubectl-plugin] Fix no context nil error SIGSEGV in tests (#2892)

Signed-off-by: Chi-Sheng Liu <chishengliu@chishengliu.com>

* [CI] Enable testifylint rule (#2896)

Signed-off-by: Chi-Sheng Liu <chishengliu@chishengliu.com>

* [CI] Enable `testifylint` `error-nil` rule (#2907)

* [kubectl-plugin][feat] support specifying number of head GPUs (#2895)

when creating a RayCluster with `kubectl ray create cluster NAME --head-gpu N`.
Similar to the `--worker-gpu` switch.

Signed-off-by: David Xia <david@davidxia.com>

* Use webhook.CustomValidator instead of deprecated webhook.Validator. (#2803)

* Use webhook.CustomValidator instead of deprecated webhook.Validator.

* Move RayClusterWebhook to pkg/webhook/v1.

* [kubectl-plugin] update context error messages (#2891)

to tell user they can use `--context` to set the K8s context.

Add tests

Signed-off-by: David Xia <david@davidxia.com>
Co-authored-by: Chi-Sheng Liu <chishengliu@chishengliu.com>

* update version for v1.3.0-rc.0 (#2885)

Signed-off-by: Andrew Sy Kim <andrewsy@google.com>

---------

Signed-off-by: Rueian <rueiancsie@gmail.com>
Signed-off-by: kaihsun <kaihsun@anyscale.com>
Signed-off-by: David Xia <david@davidxia.com>
Signed-off-by: Chi-Sheng Liu <chishengliu@chishengliu.com>
Signed-off-by: Andrew Sy Kim <andrewsy@google.com>
Co-authored-by: Rueian <rueiancsie@gmail.com>
Co-authored-by: Kai-Hsun Chen <kaihsun@anyscale.com>
Co-authored-by: David Xia <david@davidxia.com>
Co-authored-by: Chi-Sheng Liu <chishengliu@chishengliu.com>
Co-authored-by: David Xia <dxia@spotify.com>
Co-authored-by: Mykhailo Bobrovskyi <mikhail.bobrovsky@gmail.com>
andrewsykim added a commit that referenced this pull request Feb 10, 2025
* [RayService] More envtests that follow the most common scenario in the RayService code path (#2880)

Signed-off-by: Rueian <rueiancsie@gmail.com>

* [RayService] Remove outdated env tests (#2886)

Signed-off-by: kaihsun <kaihsun@anyscale.com>

* [RayService] Refactor envtests (#2888)

* [docs][ray-operator] fix typo in Golang version (#2893)

Project uses Golang 1.22 not 1.20.

Signed-off-by: David Xia <david@davidxia.com>

* [Fix][kubectl-plugin] Fix no context nil error SIGSEGV in tests (#2892)

Signed-off-by: Chi-Sheng Liu <chishengliu@chishengliu.com>

* [CI] Enable testifylint rule (#2896)

Signed-off-by: Chi-Sheng Liu <chishengliu@chishengliu.com>

* [CI] Enable `testifylint` `error-nil` rule (#2907)

* [kubectl-plugin][feat] support specifying number of head GPUs (#2895)

when creating a RayCluster with `kubectl ray create cluster NAME --head-gpu N`.
Similar to the `--worker-gpu` switch.

Signed-off-by: David Xia <david@davidxia.com>

* Use webhook.CustomValidator instead of deprecated webhook.Validator. (#2803)

* Use webhook.CustomValidator instead of deprecated webhook.Validator.

* Move RayClusterWebhook to pkg/webhook/v1.

* [kubectl-plugin] update context error messages (#2891)

to tell user they can use `--context` to set the K8s context.

Add tests

Signed-off-by: David Xia <david@davidxia.com>
Co-authored-by: Chi-Sheng Liu <chishengliu@chishengliu.com>

* [Fix][kubectl-plugin] make tests use a temporary kube config (#2894)

file that's not at the default path. Right now tests fail if there's a K8s
current context set with a command like `kubectl config use-context
my-context`.

This change allows tests to pass regardless of current context.

Signed-off-by: David Xia <david@davidxia.com>

* [CI] Enable testifylint formatter rule (#2915)

Signed-off-by: 400Ping <43886578+400Ping@users.noreply.github.com>

* [CI] Enable `testifylint` `empty` rule (#2908)

* [CI] Enable testifylint bool-compare rule (#2911)

Signed-off-by: 400Ping <43886578+400Ping@users.noreply.github.com>

* [CI] Auto download golang tools in pre-commit (#2917)

Signed-off-by: Chi-Sheng Liu <chishengliu@chishengliu.com>

* [RayService] a safeguard for preventing overriding the pending cluster during a upgrade (#2887)

Signed-off-by: Rueian <rueiancsie@gmail.com>

* [RayService] Refactor unit tests for ShouldPrepareNewCluster (#2928)

Signed-off-by: kaihsun <kaihsun@anyscale.com>

* [chore][kubectl-plugin] use consistent capitalization (#2922)

in comments and console messages.

* capitalize "Ray" when used as a proper noun
* capitalize Ray K8s CRDs like "RayJob" and "RayCluster"
* capitalize acronyms like "YAML"
* fix some minor typos

No functional changes.

Signed-off-by: David Xia <david@davidxia.com>

* [CI] Enable `testifylint` `require-error` rule (#2909)

* [kubectl-plugin] support general `kubectl` switches like `--context` (#2883)

* [CI] Fix lint error (require-error) (#2931)

Signed-off-by: Chi-Sheng Liu <chishengliu@chishengliu.com>

* [CI] Enable `testifylint` `float-compare` rule (#2910)

* [docs] move pre-commit instructions to main dev docs (#2921)

* [CI] Enable `testifylint` `expected-actual` rule (#2914)

* [CI] Generate CRD json schema separately in pre-commit (#2930)

* [release][1/N] Update YAMLs from Ray 2.9 to Ray 2.41 (#2934)

* Delete `[raycluster|rayjob|rayservice]_types_test.go` unnecessary tests (#2935)

* [release][2/N] Update RayCluster Helm chart from Ray 2.9 to Ray 2.41 (#2936)

Signed-off-by: kaihsun <kaihsun@anyscale.com>

* [release][3/N] Update RayService e2e tests YAML files from Ray 2.9 to Ray 2.41 (#2937)

* [release][4/N] Update Ray images / versions in kubectl plugin (#2938)

Signed-off-by: kaihsun <kaihsun@anyscale.com>

* [release][5/N] Update some RayJob YAMLs from Ray 2.9 to Ray 2.41 (#2941)

Signed-off-by: kaihsun <kaihsun@anyscale.com>

* [release][6/N] Remove unnecessary YAMLs (#2946)

Signed-off-by: kaihsun <kaihsun@anyscale.com>

* [docs][kubectl-plugin] add dev docs (#2912)

Signed-off-by: David Xia <david@davidxia.com>
Co-authored-by: Chi-Sheng Liu <chishengliu@chishengliu.com>

* [CI] Add shellcheck and fix error of it (#2933)

* [chore][kubectl-plugin] use better test assertions (#2955)

Fix two places.

* use `assert.EqualError()` instead of `assert.Error()` to check the error
  string is what we expect
* use testify assertion instead of string checking for better error output

Signed-off-by: David Xia <david@davidxia.com>

* [chore] add Markdown linting pre-commit hook (#2953)

Ignore most rules we violate for now.
Fix these two violations.

```
pre-commit run markdownlint --all-files --show-diff-on-failure

...
clients/python-client/README.md:106 MD001/heading-increment Heading levels should only increment by one level at a time [Expected: h3; Actual: h4]
CHANGELOG.md:420:1 MD030/list-marker-space Spaces after list markers [Expected: 1; Actual: 2]
```

Signed-off-by: David Xia <david@davidxia.com>

* [chore][kubectl-plugin] use consistent capitalization (#2950)

in comments and console messages.

capitalize "Ray" when used as a proper noun. Similar to #2922.

Signed-off-by: David Xia <david@davidxia.com>

* [Fix][RayJob] Invalid quote for RayJob submitter (#2949)

Closes: #2943

Signed-off-by: Chi-Sheng Liu <chishengliu@chishengliu.com>

* [release][7/N] Update RayService YAMLs (#2956)

* [CI] Enable testifylint len rule (#2945)

Signed-off-by: LeoLiao123 <leoyeepaa@gmail.com>

* [docs][kubectl-plugin] improve help messages (#2952)

Signed-off-by: David Xia <david@davidxia.com>

* [kubectl-plugin] Fix panic when GPU resource is not set (#2954)

Signed-off-by: win5923 <ken89@kimo.com>

* [release][8/N] Upgrade Stable Diffusion RayService to Ray 2.41 (#2960)

* [docs][kubectl-plugin] fix incorrect example commands (#2951)

Signed-off-by: David Xia <david@davidxia.com>
Co-authored-by: Chi-Sheng Liu <chishengliu@chishengliu.com>

* [fix][kubectl-plugin] set worker group CPU limit (#2958)

when creating a new worker group with `kubectl ray create workergroup`.
Write a unit test.

I noticed we are setting resource limits equal to resource requests everywhere
else but in this command. I have a K8s [LimitRange] that prevented the creation
of these worker Pods that had CPU limit defaulting to less than their CPU
requests. Describing the RayCluster showed this warning event.

`Failed to create worker Pod hyperkube/, Pod
"dxia-test-other-group-worker-pm2sh" is invalid:
spec.containers[0].resources.requests: Invalid value: "2": must be less than or
equal to cpu limit of 250m`

Signed-off-by: David Xia <david@davidxia.com>

[LimitRange]: https://kubernetes.io/docs/concepts/policy/limit-range/

* [RayJob] Deflaky RayJob e2e tests (#2963)

Signed-off-by: kaihsun <kaihsun@anyscale.com>

* [RayService] Deflaky RayService envtest (#2962)

Signed-off-by: kaihsun <kaihsun@anyscale.com>

* [release][9/N] Update text summarizer RayService to Ray 2.41 (#2961)

* [RayService] adapter vllm 0.6.1.post2 (#2823)

* adapter vllm 0.6.1.post2

* fix var define

* Unify the cpu Settings in serve.py in service.yaml, all set to 1

* Maintain the configuration with vllm0.5x

* [Release] Upgrade ray-job.batch-inference.yaml image to 2.41 (#2971)

Signed-off-by: Chi-Sheng Liu <chishengliu@chishengliu.com>

* [chore][docs] enable Markdownlint rule MD010 (#2975)

* [CI] Change Pre-commit-shellcheck-to-shellcheck-py (#2974)

Signed-off-by: owenowenisme <mses010108@gmail.com>

* [release] Update Yunikorn YAML file to Ray 2.41 (#2969)

Signed-off-by: Cheng-Yeh Chung <kenchung285@gmail.com>

* [release] Update YuniKorn YAML files to Ray 2.41 (#2976)

Signed-off-by: win5923 <ken89@kimo.com>

* [chore][docs] enable Markdownlint rule MD004 (#2973)

[Unordered list style][1]

[1]: https://github.com/DavidAnson/markdownlint/blob/main/doc/Rules.md#md004---unordered-list-style

* [Test] Use GcsFaultToleranceOptions in test and backward compatibility (#2972)

* Update samples to use Ray 2.41.0 images (#2964)

Signed-off-by: Andrew Sy Kim <andrewsy@google.com>

* Update TPU Ray CR manifests to use Ray 2.41.0 (#2965)

* [Refactor] Use constants for image tag, image repo, and versions in golang to avoid hard-coded strings (#2978)

---------

Signed-off-by: Rueian <rueiancsie@gmail.com>
Signed-off-by: kaihsun <kaihsun@anyscale.com>
Signed-off-by: David Xia <david@davidxia.com>
Signed-off-by: Chi-Sheng Liu <chishengliu@chishengliu.com>
Signed-off-by: 400Ping <43886578+400Ping@users.noreply.github.com>
Signed-off-by: LeoLiao123 <leoyeepaa@gmail.com>
Signed-off-by: win5923 <ken89@kimo.com>
Signed-off-by: owenowenisme <mses010108@gmail.com>
Signed-off-by: Cheng-Yeh Chung <kenchung285@gmail.com>
Signed-off-by: Andrew Sy Kim <andrewsy@google.com>
Co-authored-by: Rueian <rueiancsie@gmail.com>
Co-authored-by: Kai-Hsun Chen <kaihsun@anyscale.com>
Co-authored-by: David Xia <david@davidxia.com>
Co-authored-by: Chi-Sheng Liu <chishengliu@chishengliu.com>
Co-authored-by: David Xia <dxia@spotify.com>
Co-authored-by: Mykhailo Bobrovskyi <mikhail.bobrovsky@gmail.com>
Co-authored-by: Ping <43886578+400Ping@users.noreply.github.com>
Co-authored-by: Owen Lin <106612301+owenowenisme@users.noreply.github.com>
Co-authored-by: Leo Liao <93932709+LeoLiao123@users.noreply.github.com>
Co-authored-by: Blocka <ken89@kimo.com>
Co-authored-by: zrant <37032227+pxp531@users.noreply.github.com>
Co-authored-by: kenchung285 <kenchung285@gmail.com>
Co-authored-by: fscnick <6858627+fscnick@users.noreply.github.com>
Co-authored-by: ryanaoleary <113500783+ryanaoleary@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants