Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
89499: build/README: link to the wiki page on dependencies r=rickystewart a=knz

Release note: None

90689: clisqlshell: fix the behavior of ctrl+c under `--no-line-editor` r=andreimatei a=knz

Fixes cockroachdb#90653.

Prior to this commit, there was a race condition in the cancellation goroutine, between re-sending the signal and control flowing out of the conditional into a call to a (nil) cancelFn.

This commit fixes that.

(No release note because the feature has not been released yet.)

Release note: None

90710: ttl: fix incorrect roachpb.RKey decoding error output r=rafiss a=ecwall

fixes cockroachdb#90707

`fmt.Sprintf("%x", rKey))` incorrectly outputs a hex encoded string of the pretty print output of a RKey (via RKey.String()). `fmt.Sprintf("%x", []byte(rKey)))` correctly outputs a hex encoded string of the RKey []byte itself.

Release note (bug fix): TTL decoding error messages now correctly contain hex encoded key bytes instead of hex encoded key pretty print output.

Co-authored-by: Raphael 'kena' Poss <[email protected]>
Co-authored-by: Evan Wall <[email protected]>
  • Loading branch information
3 people committed Oct 26, 2022
4 parents 8310d91 + 5eed5b3 + 8cb34c6 + d8dd140 commit f64c283
Show file tree
Hide file tree
Showing 4 changed files with 82 additions and 36 deletions.
66 changes: 43 additions & 23 deletions build/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -158,44 +158,59 @@ file on your local branch, 2) push a commit containing this import to the `vendo

## Working Locally with Dependencies

### Installing a Dependency
1. In `cockroachdb/cockroach`, switch to the local branch you plan to import the external package
### Installing a new Dependency

1. Familiarize yourself with [our wiki page on adding or updating
dependencies](https://wiki.crdb.io/wiki/spaces/CRDB/pages/181862804/Adding%2C+Updating+and+Deleting+external+dependencies).
In particular, you will need to go first through a non-technical step
related to checking the license of the dependency. This is
important and non-optional.
2. In `cockroachdb/cockroach`, switch to the local branch you plan to import the external package
into
2. Run `go get -u <dependency>`. To get a specific version, run `go get -u
3. Run `go get -u <dependency>`. To get a specific version, run `go get -u
<dependency>@<version|branch|sha>`. You should see changes in `go.mod` when running `git diff`.
3. Import the dependency to a go file in `cockorachdb/cockroach`. You may use an anonymous
4. Import the dependency to a go file in `cockroachdb/cockroach`. You may use an anonymous
import, e.g. `import _ "golang.org/api/compute/v1"`, if you haven't written any code that
references the dependency. This ensures cockroach's make file will properly add the package(s) to the vendor directory. Note that IDEs may bicker that
these import's paths don't exist. That's ok!
4. Run `go mod tidy` to ensure stale dependencies are removed.
5. Run `make vendor_rebuild` to add the package to the vendor directory. Note this command will only
5. Run `go mod tidy` to ensure stale dependencies are removed.
6. Run `make vendor_rebuild` to add the package to the vendor directory. Note this command will only
add packages you have imported in the codebase (and any of the package's dependencies), so you
may want to add import statements for each package you plan to use (i.e. repeat step 3 a couple times).
6. Run `cd vendor && git diff && cd ..` to ensure the vendor directory contains the package(s)
7. Run `cd vendor && git diff && cd ..` to ensure the vendor directory contains the package(s)
you imported
7. Run `make buildshort` to ensure your code compiles.
8. Run `./dev generate bazel --mirror` to regenerate DEPS.bzl with the updated Go dependency information.
8. Run `make buildshort` to ensure your code compiles.
9. Run `./dev generate bazel --mirror` to regenerate DEPS.bzl with the updated Go dependency information.
Note that you need engineer permissions to mirror dependencies; if you want to get the Bazel build
working locally without mirroring, `./dev generate bazel` will work, but you won't be able to check
your changes in. (Assuming that you do have engineer permissions, you can run
`gcloud auth application-default login` to authenticate if you get a credentials error.)
9. Follow instructions for [pushing the dependency to the `vendored` submodule](#pushing-the-dependency-to-the-vendored-submodule)
10. Follow instructions for [pushing the dependency to the `vendored` submodule](#pushing-the-dependency-to-the-vendored-submodule)

### Updating a Dependency
Follow the instructions for [Installing a Dependency](#installing-a-dependency). Note:

Follow the instructions for [Installing a Dependency](#installing-a-dependency).

Note:

- You will still need to pay extra attention to the licensing step as
described in [the wiki
page](https://wiki.crdb.io/wiki/spaces/CRDB/pages/181862804/Adding%2C+Updating+and+Deleting+external+dependencies).
- If you're only importing a new package from an existing module in `go.mod`, you don't need to
re-download the module, step 2 above.
re-download the module, step 2 above.
- If you're only updating the package version, you probably don't need to update the import
statements, step 3 above.
statements, step 3 above.

When [pushing the dependency to the `vendored` submodule](#pushing-the-dependency-to-the-vendored-submodule), you may either checkout a new branch, or create a new commit in the original branch you used to publicize the vendor
dependency.

### Removing a dependency

When a dependency has been removed, run `go mod tidy` and then `make vendor_rebuild`.
Then follow the [Pushing the Dependency to the `vendored` submodule](#pushing-the-dependency-to-the-vendored-submodule) steps.

## Working With Submodules

To keep the bloat of all the changes in all our dependencies out of our main
repository, we embed `vendor` as a git submodule, storing its content and
history in [`vendored`](https://github.com/cockroachdb/vendored) instead.
Expand All @@ -205,29 +220,34 @@ changed dependencies require a two step process. After altering dependencies and
changes, follow the steps below.

### Pushing the Dependency to the `vendored` submodule
- Notice that `git status` in `cockroachdb/cockroach` checkout will report that the
`vendor` submodule has `modified/untracked content`.

- Notice that `git status` in `cockroachdb/cockroach` checkout will
report that the `vendor` submodule has `modified/untracked content`.

- `cd` into `vendor`, and ...
+ Checkout a **new** named branch
+ Run `git add .`
+ Commit all changes, with a nice short message. There's no explicit policy related to commit
messages in the vendored submodule.

- At this point the `git status` in your `cockroachdb/cockroach` checkout will report `new commits`
for `vendor` instead of `modified content`.
- Back in your `cockroachdb/cockroach` branch, commit your code changes and the new `vendor`
submodule ref.
- At this point the `git status` in your `cockroachdb/cockroach`
checkout will report `new commits` for `vendor` instead of `modified
content`.
- Back in your `cockroachdb/cockroach` branch, commit your code
changes and the new `vendor` submodule ref.

- Before the `cockroachdb/cockroach` commit can be submitted in a pull request, the submodule commit
it references must be available on `github.com/cockroachdb/vendored`. So, when you're ready to
publicize your vendor changes, push the `vendored` commit to remote:

+ Organization members can push their named branches there directly, via:
+ `git push [remote vendor name, probably 'origin'] [your vendor branch] `
+ Non-members should fork the `vendored` repo and submit a pull request to
`cockroachdb/vendored`, and need wait for it to merge before they will be able
to use it in a `cockroachdb/cockroach` PR.

`git push [remote vendor name, probably 'origin'] [your vendor branch] `

+ Non-members should fork the `vendored` repo and submit a pull
request to `cockroachdb/vendored`, and need wait for it to merge
before they will be able to use it in a `cockroachdb/cockroach`
PR.

### `master` Branch Pointer in Vendored Repo

Expand Down
1 change: 1 addition & 0 deletions pkg/cli/clisqlshell/sql.go
Original file line number Diff line number Diff line change
Expand Up @@ -2358,6 +2358,7 @@ func (c *cliState) maybeHandleInterrupt() func() {
// by re-throwing the signal after stopping the signal capture.
signal.Reset(os.Interrupt)
_ = sysutil.InterruptSelf()
return
}

fmt.Fprintf(c.iCtx.stderr, "\nattempting to cancel query...\n")
Expand Down
27 changes: 24 additions & 3 deletions pkg/cli/interactive_tests/test_interrupt.tcl
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
#! /usr/bin/env expect -f

# Disabled until https://github.com/cockroachdb/cockroach/issues/76483 is resolved.

source [file join [file dirname $argv0] common.tcl]

start_server $argv
Expand Down Expand Up @@ -47,9 +45,32 @@ send "\r"
eexpect "defaultdb>"
end_test

# Quit the SQL client, and open a unix shell.
# Quit the SQL client.
send_eof
eexpect eof

start_test "Check that interrupt without a line editor quits the shell."
# regression test for #90653.
spawn $argv sql --no-line-editor
eexpect "defaultdb>"
interrupt
set timeout 1
expect {
"attempting to cancel query" { exit 1 }
"panic: runtime error" { exit 1 }
timeout {}
}
set timeout 30
interrupt
expect {
"attempting to cancel query" { exit 1 }
"panic: runtime error" { exit 1 }
eof {}
}
end_test


# Open a unix shell.
spawn /bin/bash
set shell2_spawn_id $spawn_id
send "PS1=':''/# '\r"
Expand Down
24 changes: 14 additions & 10 deletions pkg/sql/ttl/ttljob/ttljob_processor.go
Original file line number Diff line number Diff line change
Expand Up @@ -387,40 +387,44 @@ func (t *ttlProcessor) runTTLOnSpan(

// keyToDatums translates a RKey on a span for a table to the appropriate datums.
func keyToDatums(
key roachpb.RKey, codec keys.SQLCodec, pkTypes []*types.T, alloc *tree.DatumAlloc,
rKey roachpb.RKey, codec keys.SQLCodec, pkTypes []*types.T, alloc *tree.DatumAlloc,
) (tree.Datums, error) {

rKey := key.AsRawKey()
key := rKey.AsRawKey()

// Decode the datums ourselves, instead of using rowenc.DecodeKeyVals.
// We cannot use rowenc.DecodeKeyVals because we may not have the entire PK
// as the key for the span (e.g. a PK (a, b) may only be split on (a)).
rKey, err := codec.StripTenantPrefix(rKey)
key, err := codec.StripTenantPrefix(key)
if err != nil {
return nil, errors.Wrapf(err, "error decoding tenant prefix of %x", key)
// Convert rKey to []byte to prevent hex encoding output of RKey.String().
return nil, errors.Wrapf(err, "error decoding tenant prefix of %x", []byte(rKey))
}
rKey, _, _, err = rowenc.DecodePartialTableIDIndexID(rKey)
key, _, _, err = rowenc.DecodePartialTableIDIndexID(key)
if err != nil {
return nil, errors.Wrapf(err, "error decoding table/index ID of key=%x", key)
// Convert rKey to []byte to prevent hex encoding output of RKey.String().
return nil, errors.Wrapf(err, "error decoding table/index ID of %x", []byte(rKey))
}
encDatums := make([]rowenc.EncDatum, 0, len(pkTypes))
for len(rKey) > 0 && len(encDatums) < len(pkTypes) {
for len(key) > 0 && len(encDatums) < len(pkTypes) {
i := len(encDatums)
// We currently assume all PRIMARY KEY columns are ascending, and block
// creation otherwise.
enc := descpb.DatumEncoding_ASCENDING_KEY
var val rowenc.EncDatum
val, rKey, err = rowenc.EncDatumFromBuffer(pkTypes[i], enc, rKey)
val, key, err = rowenc.EncDatumFromBuffer(pkTypes[i], enc, key)
if err != nil {
return nil, errors.Wrapf(err, "error decoding EncDatum of %x", key)
// Convert rKey to []byte to prevent hex encoding output of RKey.String().
return nil, errors.Wrapf(err, "error decoding EncDatum of %x", []byte(rKey))
}
encDatums = append(encDatums, val)
}

datums := make(tree.Datums, len(encDatums))
for i, encDatum := range encDatums {
if err := encDatum.EnsureDecoded(pkTypes[i], alloc); err != nil {
return nil, errors.Wrapf(err, "error ensuring encoded of %x", key)
// Convert rKey to []byte to prevent hex encoding output of RKey.String().
return nil, errors.Wrapf(err, "error ensuring encoding of %x", []byte(rKey))
}
datums[i] = encDatum.Datum
}
Expand Down

0 comments on commit f64c283

Please sign in to comment.