-
-
Notifications
You must be signed in to change notification settings - Fork 84
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
start playing with hat tests #1815
base: main
Are you sure you want to change the base?
Conversation
8610ad1
to
f8770ab
Compare
to discuss (notes to self):
todo (notes to self):
|
1190188
to
9179428
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just left quick comment; haven't really reviewed
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh wow ok. We were planning to just use https://github.com/microsoft/vscode-languageserver-node as we'll need that for lsp anyway 😅. Looks like your code goes a bit further, as they stop at text document and you go all the way to editor. But would be good to use as much of their code as possible as we'll be pulling that in anyway
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@pokey I went to pull this in and hit a speed bump. Their TextDocument type implements a smaller interface than the cursorless TextDocument interface:
Type 'TextDocument' is missing the following properties from type 'TextDocument': range, eol, lineAt ts(2739)
Range and eol are trivial, but unfortunately, lineAt returns a non-trivial TextLine interface, so there's a meaningful amount of code missing.
I could try to (a) shrink our interface or (b) build our mock document as a wrapper around theirs, harder because of the TextLine thing, or (c) just continue with our own top-to-bottom mock. Or I guess (d) try to upstream code to make theirs match our needs.
Thoughts?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd lean towards a), falling back to b) as necessary
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sigh. Plan B isn't promising either. We still need our implementation of TextLine, and re-implementing the rest in terms of their interface is janky. Not done, but the diff-stat isn't overwhelming:
packages/common/src/testUtil/mockEditor.ts | 51 +++++++++++++++++----------------------------------
I think we should either (a) have you take a crack at this or (b) discuss again at a meet-up. Maybe there's something clever we can do that I'm missing...but these two interfaces don't line up nicely.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Moved this discussion to #1882
update from meeting: this is promising. i will continue to tinker with it. |
1857eb7
to
59206d4
Compare
this is the sort of thing that I could accidentally tinker with forever. there are lots of improvements that can be made and lots of directions to go. but the best possible direction is submitted, where it can be improved incrementally. :) I know that this cannot go in as it is--it is lacking a fair bit of polish--but I would like to start the review process, because I think it will take several iterations. (btw, this currently includes #1825, because it is ~unusable without it.) feel free to only do a high level review at this point if you would prefer. over voice would also be okay. up to you. |
also, if you have any talon, python or typescript files of a medium-ish length, with no licensing issues, and that doesn't pertain directly to cursorless (so that it doesn't constantly appear when we grep the codebase), I love to add them... |
update from meetup:
|
8e8d3a1
to
c9213b3
Compare
current status early reviewer input requestedcan happen concurrently with my next steps
my next steps
once all these are done, then we can move on to a regular, full, code-level review. |
chatgpt? 😄 Happy to add some tho if you prefer
yep makes sense
not sure if this is what you're after, but we should have a launch config that updates fixtures only for the unit tests. should be trivial to add. and that won't pop up the extension window at all I believe |
@@ -0,0 +1,159 @@ | |||
_ _ _ _ _ _ | |||
// Package intern interns strings. | |||
[] [-----] [----] [-----] [-----]| |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think I like this convention
func String(s string) string { | ||
[--] [----]|| [----]| [----] | | ||
|
||
B AA B 1 B CC2D B A3 A4 D |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What do all these letters / numbers mean? I guess they're colors / shapes. And colored shape uses two rows?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I added detail to the readme
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
where's the cursor? always at 0:0
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
added to read me
▁▁▁▁▁▁▃▁▃▁▁▁▃▃▁▁▁▃▁▁▃▁▁▃▁▁▃▃▃▁▁▃▃▁▃▁▃▃▃▃▃▁▃▃▁▃▃▃▃▃▃▃▁▃▃▃▁▃▁▃ | ||
▁▁▃▃▁▃▃▃▃▃▁▃▁▃▃▃▁▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃ | ||
▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▅▃▃▃▃▃▃▃▅▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▅▃▃▃▃▃ | ||
▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▃▅▃▃▃▃▃▃▃▅▃▃▃▃▃▃▃▃▅▃▃▅▃▅▃▅▃▅▃▅▃ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
how am I supposed to read this chart? Is the x tokens, and the y penalty?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
added to read me, please let me know if it is insufficient
nHats: | ||
mean: 100% | ||
std: 0% | ||
min: 100% | ||
max: 100% | ||
spark: 0 25 50 75 █ 100 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what do these statistics mean?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
added to read me
std: 1% | ||
min: 80% | ||
max: 82% | ||
spark: 0 25 50 75 ▂█▆ 100 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what's this funny shape?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
added to read me, might not be sufficient, please let me know if you still have questions
I'd rather use human written code. I'll grab some from a friend if you don't have some handy.
done |
4e8fefd
to
53a07b8
Compare
i have sinned...force pushed. sorry. will switch back to regular review mode now. |
this is interesting because of the low number of nPenalty0 hats.
.gitattributes
Outdated
@@ -0,0 +1,3 @@ | |||
# do not modify line endings of our hat test golden files | |||
packages/cursorless-engine/src/test/fixtures/hat-stats/*.golden -crlf |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I thought the attribute is called eol=lf
, or -text
for "don't mangle this at all"
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh no not this again 😅. What's the issue you're trying to solve here @josharian?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It’s solved now, thanks to @auscompgeek .
The issue was that git was adding CR to the golden files on checkout, so the test that the golden files were unmodified was failing.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would prefer to avoid gitattributes if at all possible. If people want to check things out as CRLF, I don't see why we should get in the way of that. The last time we ran into this problem, we solved it by normalizing when we read the gold file. See
cursorless/packages/cursorless-vscode-e2e/src/suite/testCaseRecorder.vscode.test.ts
Lines 169 to 171 in 5789094
// We use this to ensure that the test works on Windows. Depending on user | |
// / CI git config, the file might be checked out with CRLF line endings | |
.replaceAll("\r\n", "\n"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
OK. If you look at the commit history, I’ve also implemented that, when you gitattributes originally did not work. Although to avoid needless diffs, we also have to normalize at writing time as well…sigh.
marking as draft until #1882 is sorted |
- Extracted from #1815 ## Checklist - [-] I have added [tests](https://www.cursorless.org/docs/contributing/test-case-recorder/) - [-] I have updated the [docs](https://github.com/cursorless-dev/cursorless/tree/main/docs) and [cheatsheet](https://github.com/cursorless-dev/cursorless/tree/main/cursorless-talon/src/cheatsheet) - [-] I have not broken the cheatsheet
- Extracted from cursorless-dev#1815 ## Checklist - [-] I have added [tests](https://www.cursorless.org/docs/contributing/test-case-recorder/) - [-] I have updated the [docs](https://github.com/cursorless-dev/cursorless/tree/main/docs) and [cheatsheet](https://github.com/cursorless-dev/cursorless/tree/main/cursorless-talon/src/cheatsheet) - [-] I have not broken the cheatsheet
for voice discussion. definitely work in progress.