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

Add basic support for blkdiscard #159

Merged
merged 1 commit into from
May 30, 2024
Merged

Conversation

ScottGarman
Copy link
Contributor

@ScottGarman ScottGarman commented May 29, 2024

blkdiscard is a pretty basic command, it simply gets run against a block device, and returns an exit code. We always include the --force flag.

How has this been tested?

On an Equinix Metal server with several spare disks, I've modified the examples/blkdiscard/main.go to point to one of these disks and confirmed that:

  • The command succeeds in the happy path, and wipes the disk device which I had previously created a filesystem on
  • The command is correctly using the --force flag, and will discard blocks even on a mounted disk device
  • The command fails when it tries to run against a non-existent disk device
  • The command fails when I set the context timeout to too low of a value (e.g, 1 second)

Description for changelog/release notes

Add support for blkdiscard command

@ScottGarman ScottGarman force-pushed the bms-711-add-blkdiscard3 branch from 3be4d2e to fd935ea Compare May 29, 2024 21:18
@ScottGarman ScottGarman marked this pull request as ready for review May 29, 2024 21:21
mmlb
mmlb previously approved these changes May 30, 2024
utils/blkdiscard.go Outdated Show resolved Hide resolved
blkdiscard is a pretty basic command, it simply gets run against a block
device, and returns an exit code. We always include the --force flag.

Signed-off-by: Scott Garman <sgarman@equinix.com>
@ScottGarman ScottGarman force-pushed the bms-711-add-blkdiscard3 branch from ccdb0b7 to efd29a0 Compare May 30, 2024 17:06
@ScottGarman ScottGarman merged commit 41022f4 into main May 30, 2024
6 checks passed
@ScottGarman ScottGarman deleted the bms-711-add-blkdiscard3 branch May 30, 2024 17:21
mmlb referenced this pull request in metal-toolbox/vogelkop Jun 14, 2024
[![Mend
Renovate](https://app.renovatebot.com/images/banner.svg)](https://renovatebot.com)

This PR contains the following updates:

| Package | Change | Age | Adoption | Passing | Confidence |
|---|---|---|---|---|---|
|
[github.com/metal-toolbox/ironlib](https://github.com/metal-toolbox/ironlib)
| `v0.2.18-0.20240611133518-3514176030a4` -> `v0.2.18` |
[![age](https://developer.mend.io/api/mc/badges/age/go/github.com%2fmetal-toolbox%2fironlib/v0.2.18?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![adoption](https://developer.mend.io/api/mc/badges/adoption/go/github.com%2fmetal-toolbox%2fironlib/v0.2.18?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![passing](https://developer.mend.io/api/mc/badges/compatibility/go/github.com%2fmetal-toolbox%2fironlib/v0.2.18-0.20240611133518-3514176030a4/v0.2.18?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![confidence](https://developer.mend.io/api/mc/badges/confidence/go/github.com%2fmetal-toolbox%2fironlib/v0.2.18-0.20240611133518-3514176030a4/v0.2.18?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|

---

### Release Notes

<details>
<summary>metal-toolbox/ironlib
(github.com/metal-toolbox/ironlib)</summary>

###
[`v0.2.18`](https://github.com/metal-toolbox/ironlib/releases/tag/v0.2.18)

[Compare
Source](https://github.com/metal-toolbox/ironlib/compare/v0.2.17...v0.2.18)

#### What's Changed

- Vc/instrument firmware by
[@&#8203;DoctorVin](https://github.com/DoctorVin) in
[https://github.com/metal-toolbox/ironlib/pull/123](https://github.com/metal-toolbox/ironlib/pull/123)
- Dockerfile: add support to build non-dist image by
[@&#8203;joelrebel](https://github.com/joelrebel) in
[https://github.com/metal-toolbox/ironlib/pull/124](https://github.com/metal-toolbox/ironlib/pull/124)
- Update actions/checkout action to v4 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/112](https://github.com/metal-toolbox/ironlib/pull/112)
- House/spring cleaning by [@&#8203;mmlb](https://github.com/mmlb) in
[https://github.com/metal-toolbox/ironlib/pull/128](https://github.com/metal-toolbox/ironlib/pull/128)
- ironlib is able to fill a disk with all zeros by
[@&#8203;turegano-equinix](https://github.com/turegano-equinix) in
[https://github.com/metal-toolbox/ironlib/pull/131](https://github.com/metal-toolbox/ironlib/pull/131)
- ironlib is able to detect ineffective wipes by
[@&#8203;turegano-equinix](https://github.com/turegano-equinix) in
[https://github.com/metal-toolbox/ironlib/pull/135](https://github.com/metal-toolbox/ironlib/pull/135)
- House Cleaning Part 2 - Electric Boogaloo! by
[@&#8203;mmlb](https://github.com/mmlb) in
[https://github.com/metal-toolbox/ironlib/pull/133](https://github.com/metal-toolbox/ironlib/pull/133)
- Better nvme capability detection by
[@&#8203;mmlb](https://github.com/mmlb) in
[https://github.com/metal-toolbox/ironlib/pull/129](https://github.com/metal-toolbox/ironlib/pull/129)
- Quiet down tests by [@&#8203;mmlb](https://github.com/mmlb) in
[https://github.com/metal-toolbox/ironlib/pull/137](https://github.com/metal-toolbox/ironlib/pull/137)
- More refactors, fixes, etc by
[@&#8203;mmlb](https://github.com/mmlb) in
[https://github.com/metal-toolbox/ironlib/pull/141](https://github.com/metal-toolbox/ironlib/pull/141)
- chore(deps): update docker/login-action action to v3 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/118](https://github.com/metal-toolbox/ironlib/pull/118)
- chore(deps): update docker/build-push-action action to v5 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/113](https://github.com/metal-toolbox/ironlib/pull/113)
- fix(deps): update module github.com/r3labs/diff/v2 to v3 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/108](https://github.com/metal-toolbox/ironlib/pull/108)
- chore(deps): update docker/metadata-action action to v5 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/144](https://github.com/metal-toolbox/ironlib/pull/144)
- chore(deps): update actions/setup-go action to v5 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/143](https://github.com/metal-toolbox/ironlib/pull/143)
- chore(deps): update module google.golang.org/protobuf to v1.33.0
\[security] by [@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/126](https://github.com/metal-toolbox/ironlib/pull/126)
- fix(deps): update module golang.org/x/net to v0.23.0 \[security] by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/116](https://github.com/metal-toolbox/ironlib/pull/116)
- chore(deps): update docker/setup-buildx-action action to v3 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/146](https://github.com/metal-toolbox/ironlib/pull/146)
- fix(deps): update module github.com/sirupsen/logrus to v1.9.3 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/100](https://github.com/metal-toolbox/ironlib/pull/100)
- chore(deps): update anchore/sbom-action action to v0.15.11 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/99](https://github.com/metal-toolbox/ironlib/pull/99)
- fix(deps): update module github.com/tidwall/gjson to v1.17.1 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/109](https://github.com/metal-toolbox/ironlib/pull/109)
- fix(deps): update module golang.org/x/net to v0.24.0 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/145](https://github.com/metal-toolbox/ironlib/pull/145)
- chore(deps): update golangci/golangci-lint-action action to v5 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/147](https://github.com/metal-toolbox/ironlib/pull/147)
- fix(deps): update module github.com/stretchr/testify to v1.9.0 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/101](https://github.com/metal-toolbox/ironlib/pull/101)
- fix(deps): update module github.com/beevik/etree to v1.3.0 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/97](https://github.com/metal-toolbox/ironlib/pull/97)
- fix(deps): update module golang.org/x/net to v0.25.0 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/148](https://github.com/metal-toolbox/ironlib/pull/148)
- chore(deps): update github/codeql-action action to v3 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/149](https://github.com/metal-toolbox/ironlib/pull/149)
- Update CODEOWNERS by
[@&#8203;DoctorVin](https://github.com/DoctorVin) in
[https://github.com/metal-toolbox/ironlib/pull/152](https://github.com/metal-toolbox/ironlib/pull/152)
- Update modules that renovate is having trouble with by
[@&#8203;mmlb](https://github.com/mmlb) in
[https://github.com/metal-toolbox/ironlib/pull/150](https://github.com/metal-toolbox/ironlib/pull/150)
- chore(deps): update golangci/golangci-lint-action action to v6 by
[@&#8203;renovate](https://github.com/renovate) in
[https://github.com/metal-toolbox/ironlib/pull/153](https://github.com/metal-toolbox/ironlib/pull/153)
- Add DiskWipe support to nvme using sanitize by
[@&#8203;mmlb](https://github.com/mmlb) in
[https://github.com/metal-toolbox/ironlib/pull/136](https://github.com/metal-toolbox/ironlib/pull/136)
- Add format support to nvme WipeDisk by
[@&#8203;mmlb](https://github.com/mmlb) in
[https://github.com/metal-toolbox/ironlib/pull/142](https://github.com/metal-toolbox/ironlib/pull/142)
- Add ns delete/create support to nvme WipeDisk by
[@&#8203;mmlb](https://github.com/mmlb) in
[https://github.com/metal-toolbox/ironlib/pull/154](https://github.com/metal-toolbox/ironlib/pull/154)
- More clean ups by [@&#8203;mmlb](https://github.com/mmlb) in
[https://github.com/metal-toolbox/ironlib/pull/158](https://github.com/metal-toolbox/ironlib/pull/158)
- Add basic support for blkdiscard by
[@&#8203;ScottGarman](https://github.com/ScottGarman) in
[https://github.com/metal-toolbox/ironlib/pull/159](https://github.com/metal-toolbox/ironlib/pull/159)
- Some more clean ups by [@&#8203;mmlb](https://github.com/mmlb) in
[https://github.com/metal-toolbox/ironlib/pull/161](https://github.com/metal-toolbox/ironlib/pull/161)
- Rename Disk stuff -> Drive and teach diskwipe example more tricks by
[@&#8203;mmlb](https://github.com/mmlb) in
[https://github.com/metal-toolbox/ironlib/pull/163](https://github.com/metal-toolbox/ironlib/pull/163)

#### New Contributors

- [@&#8203;turegano-equinix](https://github.com/turegano-equinix) made
their first contribution in
[https://github.com/metal-toolbox/ironlib/pull/131](https://github.com/metal-toolbox/ironlib/pull/131)
- [@&#8203;ScottGarman](https://github.com/ScottGarman) made their
first contribution in
[https://github.com/metal-toolbox/ironlib/pull/159](https://github.com/metal-toolbox/ironlib/pull/159)

**Full Changelog**:
metal-toolbox/ironlib@v0.2.17...v0.2.18

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you
are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about this update
again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Mend
Renovate](https://www.mend.io/free-developer-tools/renovate/). View
repository job log
[here](https://developer.mend.io/github/metal-toolbox/vogelkop).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNy4zOTMuMCIsInVwZGF0ZWRJblZlciI6IjM3LjM5My4wIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6W119-->
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.

2 participants