-
Notifications
You must be signed in to change notification settings - Fork 30.1k
December Test Plan
The test plan for the December iteration plan December Iteration Plan.
- win @alexandrudima
- mac @jrieken
- linux @SofianHn
Verify that long text now nicely wraps across multiple lines in the debug repl both for evaluation requests and for output text.
- win @alexandrudima
- mac @jrieken
- linux @aeschli
We have changed breakpoints states and now show it differently in the UI. Verify:
- new UI properly and intuitivly reflects if breakpoints are enabled, disabled, verified or deactivated.
- breakpoints get hit / not hit depending on their enablement state
- win @dbaeumer
- mac @SofianHn
- linux @aeschli
Extension debugging is now using a new strategy to attach the debugger to the extension
- verify you can debug your extension as before
- verify you can restart debugging from the debugger side and the debugger reconnects properly
- verify you can change folders or refresh on the extension development side and the debugger reconnects
- verify closing the extension development side stops debugging
- verify stopping the session from the debugger closes the extension development window
- win @alexandrudima
- mac @joaomoreno
Verify you can change the update channel from settings.
- win @dbaeumer
- mac | linux @weinand
Verify you can change and persist the zoom factor for windows.
- negative and positive values work
- the zoom actions are still working as before but do not persist
- the change is live
- win @aeschli
- mac | linux @isidorn
Unless you include a path character in your query or enabled fuzzy matching, quick open for files should work as before:
- results are sorted properly with most relevant ones to the top
- editor history always comes first on top of matching file results
- if you narrow down a search, subsequent matching is fast and does not go to the disk (verify with a larger workspace)
Verify the new support to match on paths if included in search
- using the native path separator in the search enables matching on (workspace relative) paths for both editor history results and file matching
- more relevant results are still sorted to the top
- results are highlighted properly also in their path segment
Verify the new support for fuzzy file matching
- find and enable the new setting to enable fuzzy matching for quick open. this will only enable fuzzy matching for file search, it should not have any impact to other quick open providers, nor the editor history search
- verify results from file searches match on the entire (workspace relative) path of the file without having to use the native path separator
- verify matching happens in substrings of the path, not requiring the characters to be in sequence (e.g. "fr" would match "foo_bar")
- more relevant results are sorted to the top
- win @bpasero
- mac @egamma
- linux @SofianHn
Verify that the extensions status shows up in the status bar if you have extension errors. Verify clicking on the status bar shows all the error / warning messages to the user and that you can uninstall the extension via action in message.
- win | mac | linux @joaomoreno
In both .tsx and jsx files the following snippet
.foo>input[name="bob"]+label[for="bob"]
Should expand to
<div className="foo">\n\t<input type="text" name="bob"/>\n\t<label htmlFor="bob"></label>\n</div>
- win @dbaeumer
- linux | mac @joaomoreno
Make sure that ES6 is supported without the need to configure something. Test:
- JS code inside html supports ES6, like
let
,const
, andclass C {}
- Have no jsconfig file and make sure ES6 is supported
- create a new jsconfig.json and make sure the default is ES6 for the target property
- win | mac | linux @jrieken
The language client / server libraries now support the complete set of language features available in the extension host. Implement a sample language server with more features by taking https://github.com/Microsoft/vscode-languageserver-node-example as a starting point. Focus on the new support for CodeActions, CodeLens, Formatting and rename.
-
win | mac | linux @bpasero
-
added support for a configFile config setting, see the README.md (known limitations captured in Microsoft/vscode-tslint#16)
-
schema support for the tslint.json configuration file
-
win @aeschli
-
mac @isidorn
-
linux @aeschli
-
not platform specific
-
win/linux: Ctrl+Up, Ctrl+Down, Ctrl+PageUp, Ctrl+PageDown
-
mac: Ctrl+PageUp, Ctrl+PageDown, Cmd+PageUp, Cmd+PageDown
-
should now scroll the viewport by a line or a page.
-
win | mac | linux @isidorn
-
not platform specific
-
win/linux: Ctrl+I
-
mac: Cmd+I
-
should expand selection to the current line and, if pressed multiple times, to the following lines.
-
please check that it works on long lines where word wrapping kicks in or when using
wrappingColumn: 0
.
-
win @bpasero
-
mac @bpasero
-
linux @bpasero
-
is platform specific
-
please check that you can add and trigger keybinding rules with the following keys:
-
numpad0
-
numpad1
-
numpad2
-
numpad3
-
numpad4
-
numpad5
-
numpad6
-
numpad7
-
numpad8
-
numpad9
-
numpad_multiply
-
numpad_add
-
numpad_subtract
-
numpad_decimal
-
numpad_divide
-
win | mac | linux @weinand
-
linux @aeschli
-
not platform specific
-
Ctrl+H (mac: Cmd+Alt+F) now always focuses the replace field in the find widget.
-
Ctrl+F (mac: Cmd+F) now always focuses the find field in the find widget.
-
when focus is in the find field or the replace field in the find widget, Ctrl+Down (mac: Cmd+Down) will focus the editor.
-
Alt+C (mac: Cmd+Alt+C) now toggles case sensitive. This should work also when the find widget is hidden and should reflect in the selection highlight.
-
Alt+W (mac: Cmd+Alt+W) now toggles match whole words. This should work also when the find widget is hidden and should reflect in the selection highlight.
-
Alt+R (mac: Cmd+Alt+R) now toggles match regex. This should work also when the find widget is hidden and should reflect in the selection highlight.
- win @dbaeumer
- mac @joaomoreno
- linux @aeschli
- is platform specific
- the extension host now calls
deactivate()
anddispose()
on subscriptions pushed in theactivate()
ctx - please try to author an extension that:
- when activated, forks/spawns a process
- the forked/spawned process logs to a file if it is alive (with a timestamp)
- on
deactivate()
or through a subscription pushed in theactivate()
ctx, - the extension sends the forked/spawned process a graceful shutdown request
- the forked/spawned process listens to this graceful shutdown request and gracefully shuts down
- verify that when closing VSCode the forked/spawned process shuts down gracefully.
-
win | mac | linux @bpasero (maybe someone else needs to try, I am running into: Keyboard: Widget not showing correct values #1275)
-
is platform specific
-
please see #713 for a detailed explanation
-
TL;DR. We now have a widget to help with authoring keyboard rules and we now render UI labels taking the keyboard layout under consideration.
-
Setup: please change to a keyboard layout different than US standard. Preferably, this is the keyboard layout that your physical keyboard has.
-
The widget:
-
it only shows when authoring the
keybindings.json
file -
it is invokable via Ctrl+K Ctrl+K (mac: Cmd+K Cmd+K)
-
it is invokable via clicking on the "Define Keybinding" launcher
-
it shows an input box that reflects what VSCode sees when you press keys
-
it does not help with defining chords or seeing conflicts, etc, its intent is to help with different kb layouts.
-
no keybindings are triggered while you try keybindings
-
Escape or focus loss dismisses it
-
Enter accepts it
-
The UI labels:
-
easiest to see them in the F1 list
-
the keyboard layout is taken into account only once and then cached, so if you change keyboard layouts, you need to reload the window
-
the idea is that the keys
VK_OEM_1
, ... etc are looked up and checked what they would produce if typed under the current system keyboard layout. -
the labels then render with the produced character.
-
e.g.
Split Editor
shows underGerman (Switzerland)
as Ctrl+ä because you trigger it by pressing the keys Ctrl and the key that would produceä
. -
dead characters: Sometimes, under some kb layouts, some keys don't produce anything and act more like composing (accents). To be able to render something, we display in the UI label the value or the shiftedValue of those keys.
- any platform @joaomoreno
We're using a modified TypeScript grammar for JavaScript tokenization
- Have a look at some JavaScript files, including ES6, make sure they look fine
- Test the default light and dark theme as well as some contributed themes
- Verify all duplicates of #133
- any platform @dbaeumer
The built-in schemas have been removed. They are now offered by the extensions. The schemas are now loaded directly from the schema server. That way they are more up-to-date, but might lack descriptions
- Check hover and intellisense support for package.json, project.json, bower.json
- Test tsconfig.json, global.json and jsconfig.json
- Test that associating patterns to schema still can be done in the settings
- Test that you can configure a schema from a extension. Test an extension from a server or from a file in the extension (see #489, last comment for configuration instructions)
- any platform @isidorn
Due to the move to textmate tokenizer, there were changes in the appearance of the default light and dark theme: Some themes got far more colorful, in particular JavaScript, some languages lost colors, e.g. Jade and XML. The goal was to stay as close as possible to what we had in 0.9.0: We stick to a few major colors: blue for keywords, green for comments and red for strings.
- Test JavaScript and TypeScript in the light and dark theme, compare it our old state at https://opentools.azurewebsites.net/try. Note, new colors for method, function and parameters declarations
- Test XML, HTML, Jade, Razor, Handlebars, CSS, LESS and SASS, JSON in the light and dark theme: They should all look consistent. Check stings, comments...
- Try some of the other languages as well. Check stings, comments...
Project Management
- Roadmap
- Iteration Plans
- Development Process
- Issue Tracking
- Build Champion
- Release Process
- Running the Endgame
- Related Projects
Contributing
- How to Contribute
- Submitting Bugs and Suggestions
- Feedback Channels
- Source Code Organization
- Coding Guidelines
- Testing
- Dealing with Test Flakiness
- Contributor License Agreement
- Extension API Guidelines
- Accessibility Guidelines
Documentation