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

Cleanup master terminology (start fixing issue #11353) #11394

Merged
merged 1 commit into from
Sep 6, 2024

Conversation

bogd
Copy link
Contributor

@bogd bogd commented Jul 22, 2024

What type of PR is this?

Uncomment only one /kind <> line, hit enter to put that in a new line, and remove leading whitespaces from that line:

/kind cleanup

What this PR does / why we need it:
Cleanup old "master" terminology in kubespray

Which issue(s) this PR fixes:

Special notes for your reviewer:
As per comments on issue #11353 , I have not yet touched any potentially user-facing components (tags, variables, etc). They will eventually need modifying as well, in a future step.

When that happens, it will require a more detailed release note, but I do not know yet if that can be done in the same PR or will need a new one.
Any potentially breaking changes were kept back for a future PR.

Does this PR introduce a user-facing change?:

Cleanup older terminology, replace "master" with "control plane"

@k8s-ci-robot k8s-ci-robot added release-note-none Denotes a PR that doesn't merit a release note. do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. kind/cleanup Categorizes issue or PR as related to cleaning up code, process, or technical debt. labels Jul 22, 2024
Copy link

linux-foundation-easycla bot commented Jul 22, 2024

CLA Signed

The committers listed above are authorized under a signed CLA.

  • ✅ login: bogd / name: Bogdan Sass (345eec3)

@k8s-ci-robot k8s-ci-robot added the cncf-cla: no Indicates the PR's author has not signed the CNCF CLA. label Jul 22, 2024
@k8s-ci-robot k8s-ci-robot requested review from ErikJiang and yujunz July 22, 2024 08:17
@k8s-ci-robot
Copy link
Contributor

Welcome @bogd!

It looks like this is your first PR to kubernetes-sigs/kubespray 🎉. Please refer to our pull request process documentation to help your PR have a smooth ride to approval.

You will be prompted by a bot to use commands during the review process. Do not be afraid to follow the prompts! It is okay to experiment. Here is the bot commands documentation.

You can also check if kubernetes-sigs/kubespray has its own contribution guidelines.

You may want to refer to our testing guide if you run into trouble with your tests not passing.

If you are having difficulty getting your pull request seen, please follow the recommended escalation practices. Also, for tips and tricks in the contribution process you may want to read the Kubernetes contributor cheat sheet. We want to make sure your contribution gets all the attention it needs!

Thank you, and welcome to Kubernetes. 😃

@k8s-ci-robot k8s-ci-robot added needs-ok-to-test Indicates a PR that requires an org member to verify it is safe to test. size/L Denotes a PR that changes 100-499 lines, ignoring generated files. labels Jul 22, 2024
@k8s-ci-robot
Copy link
Contributor

Hi @bogd. Thanks for your PR.

I'm waiting for a kubernetes-sigs member to verify that this patch is reasonable to test. If it is, they should reply with /ok-to-test on its own line. Until that is done, I will not automatically test new commits in this PR, but the usual testing commands by org members will still work. Regular contributors should join the org to skip this step.

Once the patch is verified, the new status will be reflected by the ok-to-test label.

I understand the commands that are listed here.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes-sigs/prow repository.

@k8s-ci-robot k8s-ci-robot added cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. and removed cncf-cla: no Indicates the PR's author has not signed the CNCF CLA. labels Jul 22, 2024
@yankay
Copy link
Member

yankay commented Jul 24, 2024

/ok-to-test

@k8s-ci-robot k8s-ci-robot added ok-to-test Indicates a non-member PR verified by an org member that is safe to test. and removed needs-ok-to-test Indicates a PR that requires an org member to verify it is safe to test. labels Jul 24, 2024
@bogd
Copy link
Contributor Author

bogd commented Jul 24, 2024

Regarding tags, I would like to proceed as suggested in the issue comment ( #11353 ) - add control-plane tags while keeping the master tag intact (for people who reference the tag manually).

However, I am not sure how to proceed here.

The line is { role: kubernetes/control-plane, tags: master, upgrade_cluster_setup: true }, but there seem to (no longer?) be any tasks in kubernetes/control-plane with the master tag.

[ Edit: I misunderstood what the tag does here - it applies to the include_role task, not to the role itself. So we are in the situation described in the issue discussion - and back to "not sure how to proceed in fixing this". :)

Replacing the tag might impact people who call kubespray playbooks with the tag set.
Maybe we could call the include twice, once for each tag (master and control-plane) until we deprecate the old tag? ]

@k8s-ci-robot k8s-ci-robot added needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. do-not-merge/contains-merge-commits and removed needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. labels Jul 26, 2024
@bogd bogd force-pushed the remove_master_terms branch from 1c54132 to 5658cfd Compare July 26, 2024 14:59
@bogd bogd force-pushed the remove_master_terms branch from 5658cfd to 790715c Compare July 26, 2024 15:10
@mzaian
Copy link
Contributor

mzaian commented Aug 1, 2024

Regarding tags, I would like to proceed as suggested in the issue comment ( #11353 ) - add control-plane tags while keeping the master tag intact (for people who reference the tag manually).

However, I am not sure how to proceed here.

The line is { role: kubernetes/control-plane, tags: master, upgrade_cluster_setup: true }, but there seem to (no longer?) be any tasks in kubernetes/control-plane with the master tag.

[ Edit: I misunderstood what the tag does here - it applies to the include_role task, not to the role itself. So we are in the situation described in the issue discussion - and back to "not sure how to proceed in fixing this". :)

Replacing the tag might impact people who call kubespray playbooks with the tag set. Maybe we could call the include twice, once for each tag (master and control-plane) until we deprecate the old tag? ]

Hello @bogd

We could just highlight this in the release notes by adding a deprecation warning. People should take care of it when they use the new release.

@bogd
Copy link
Contributor Author

bogd commented Aug 1, 2024

Thank you, @mzaian !

Since this PR already touches multiple files, I would like to stick to "no user-facing changes" for it.

My plan is to change as much as possible without any potentially breaking changes, and keep those changes for separate PR(s) - smaller ones, easier to follow.

This means that I will not touch variables and tag references (yet). Once this is merged, I will start work on the more... troublesome changes in a separate PR. In fact, this is why the PR is marked as "start fixing issue" :)

As before, please let me know if I am missing something, or if you think I should go about this a different way.

@mzaian
Copy link
Contributor

mzaian commented Aug 1, 2024

Thank you, @mzaian !

Since this PR already touches multiple files, I would like to stick to "no user-facing changes" for it.

My plan is to change as much as possible without any potentially breaking changes, and keep those changes for separate PR(s) - smaller ones, easier to follow.

This means that I will not touch variables and tag references (yet). Once this is merged, I will start work on the more... troublesome changes in a separate PR. In fact, this is why the PR is marked as "start fixing issue" :)

As before, please let me know if I am missing something, or if you think I should go about this a different way.

I really like this approach small PRs for critical things. I have no comments but Thank you for taking care of this :)

@k8s-ci-robot k8s-ci-robot added the needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. label Aug 6, 2024
roles/etcd/tasks/main.yml Outdated Show resolved Hide resolved
@bogd bogd force-pushed the remove_master_terms branch 2 times, most recently from bd6cf5d to 5d2bee1 Compare September 2, 2024 07:54
@k8s-ci-robot k8s-ci-robot removed the needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. label Sep 2, 2024
@bogd bogd force-pushed the remove_master_terms branch 4 times, most recently from 5edcedc to c582019 Compare September 2, 2024 08:25
@bogd bogd requested a review from VannTen September 2, 2024 08:54
@bogd
Copy link
Contributor Author

bogd commented Sep 2, 2024

Quick question - if g in group_names is preferred, can't this check also be replaced?

Original:

 when:
    - inventory_hostname in groups['etcd'] | union(groups['kube_control_plane']) | unique | sort

Alternative:

 when:
    - ('etcd' in group_names) or ('kube_control_plane' in group_names)

There are multiple inventory_hostname in groups[] checks, but this one stood out in particular.

I am not trying to expand the scope of this PR (it is already big enough :) ), I am just trying to keep consistency throughout the files.

@VannTen
Copy link
Contributor

VannTen commented Sep 5, 2024

Yeah it's fine. I usually do stuff like this : group_names | intersect([<list of group_names>] | length != 0 but your way is perfectly fine as well, and certainly better than the inventory_hostname one.

@@ -13,19 +13,19 @@
service:
name: etcd
state: restarted
when: is_etcd_master
when: ('etcd' in group_names)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No need for parens here (or anywhere else if the check is standalone). Check operators have a pretty high precedence, I think.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The parentheses are there for another reason - to "escape" the quotation (otherwise, it is interpreted as a YAML quote, and the YAML parser fails to interpret the value).

This is the way I normally work around this "quote at start of YAML value" problem. If you know a better way to do it, I will implement it.

I know it is still a problem because in a previous commit I forgot to add it, and all the CI tests started failing :)

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh that's why.
I've seen mostly using the other kind of quote for that ("'etcd' in group_names") but parens look fine to me ; it can be confused precedence override, but OTOH the quotes muck up syntax highlighting, so that's a pick your poison scenario I guess.

Copy link
Contributor Author

@bogd bogd Sep 5, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For me, using two kinds of quotes is a bit less readable - I am the kind of person that always prefers explicit parentheses to relying on operator precedence, so probably that is why :)

(I am also the kind of person that often edits YAMLs in vim without syntax highlighting, but I guess that says more about my age than about anything else)

@@ -71,7 +71,7 @@
owner: "root"
mode: "0644"
when:
- not is_kube_master
- ('kube_control_plane' not in group_names)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

same for kube_control_plane on each occurence.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same reason as above - if I do not do something about the quote, the YAML parser will fail when interpreting the line.

@bogd bogd force-pushed the remove_master_terms branch from c582019 to c11add9 Compare September 5, 2024 06:17
@bogd bogd requested a review from VannTen September 5, 2024 06:18
@bogd bogd force-pushed the remove_master_terms branch from c11add9 to 9d6e886 Compare September 5, 2024 06:43
@VannTen
Copy link
Contributor

VannTen commented Sep 5, 2024

I'm fine with the content.
Can you reformat your commit message though ? Not strictly respecting git recommended title length is fine, but you should still separate the tiltle of your commit from the body with a blank line.
I suggest dropping the (part of #11353), ref to issues and PR are not super useful in commit message.

Thanks for the work 👍

@VannTen
Copy link
Contributor

VannTen commented Sep 5, 2024

@yankay @mzaian I'm fine with putting this in 2.26 if you want, but it's a rather large change, do you prefer to defer until after the release ?

@mzaian
Copy link
Contributor

mzaian commented Sep 5, 2024

@yankay @mzaian I'm fine with putting this in 2.26 if you want, but it's a rather large change, do you prefer to defer until after the release ?

I think no one tested this with different scenarios. It should be tested and then maybe go with the future 2.27 it's a bit late for 2.26

@VannTen
Copy link
Contributor

VannTen commented Sep 5, 2024 via email

@k8s-ci-robot k8s-ci-robot added the do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. label Sep 5, 2024
@bogd bogd force-pushed the remove_master_terms branch from 9d6e886 to 345eec3 Compare September 5, 2024 08:43
@VannTen
Copy link
Contributor

VannTen commented Sep 5, 2024

Thanks !
/lgtm

@k8s-ci-robot k8s-ci-robot added the lgtm "Looks good to me", indicates that a PR is ready to be merged. label Sep 5, 2024
@bogd
Copy link
Contributor Author

bogd commented Sep 5, 2024

Thanks ! /lgtm

Thank you for the help, and the guidance in getting a new contributor up to speed :)

@VannTen
Copy link
Contributor

VannTen commented Sep 6, 2024

/hold cancel

@k8s-ci-robot k8s-ci-robot removed the do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. label Sep 6, 2024
@k8s-ci-robot k8s-ci-robot merged commit 4b324cb into kubernetes-sigs:master Sep 6, 2024
52 checks passed
kpoxo6op pushed a commit to kpoxo6op/kubespray that referenced this pull request Dec 27, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
approved Indicates a PR has been approved by an approver from all required OWNERS files. ci-extended Run additional tests cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. kind/cleanup Categorizes issue or PR as related to cleaning up code, process, or technical debt. lgtm "Looks good to me", indicates that a PR is ready to be merged. ok-to-test Indicates a non-member PR verified by an org member that is safe to test. release-note Denotes a PR that will be considered when it comes time to generate release notes. size/L Denotes a PR that changes 100-499 lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants