-
Notifications
You must be signed in to change notification settings - Fork 99
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 Quick Connect #1150
Add Quick Connect #1150
Conversation
@chrjorgensen This is awesome. I personally love that this is an opt in thing. Please fix up the conflicts and then I will retest again. |
@worksofliam Conflicts fixed, please retest... |
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.
That's an awesome change and should indeed speed up connection times. Great job!
Maybe you can make a change to enhance the UX a bit more. Having to uncheck the property in the settings, connect and check again the property seems a bit cumbersome. How about having a Connect and reload settings
command that could force the reloading of the settings even if quick connect is on? This could be a right click action in the connection browser.
@sebjulliand I now added a connection right-click option to connect and reload server settings: A new command I had to add one parameter to the connect functions to specify that server settings should be reloaded, despite quick connect was set for the connection. Could I have done it better in another way? |
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 all good to me; just a suggestion to consider.
No, that's perfect the way you did it @chrjorgensen ! |
@chrjorgensen, @worksofliam : shouldn't |
@sebjulliand I am guessing this quick connect would only work after the initial connection so we have some system information. I haven't tested this PR yet |
If it's on but nothing's been cached yet, it will perform a normal connection to gather and cache the values. That's why I think it doesn't hurt to have it turned |
Yeah, Quick connect will not break if activated on a connection never used before. For each setting it will check if there's a value in the cache from a previous connection and only then use that value. Otherwise it will go to the server as usual. I'm undecided whether this setting is best suited as a connection setting or a global setting. Since it won't break anything and servers very, very rarely change settings, this could just as well be a global setting. What do you guys think? |
When you put it this way, I think it should even not be an option at all, but just the built-in behavior. I can't think of a scenario where you'd need to reload the cached settings every time. Since we have the command to reload them on demand, there may be no point to have it as an option at all. |
I somewhat agree with it. In fact, I was thinking an option like 'always do a full connect' (which means never use our cached settings) in the VS Code settings would work here. If it's false, it will: use the cached settings if they exist, otherwise do full connect and store them. If it's true.. always do a full connect |
a7f7a63
to
b8fd440
Compare
@sebjulliand This PR was so far behind master that I had to rebase the changes onto master branch and force push. |
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 a small suggestion and conflicts to resolve; I can't wait to merge this PR, it's so convenient!
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.
Everything is fine, save for one detail; it's not directly related to your PR, but it's been highlighted by it 😉
In src/webviews/settings/index.ts
, the target configuration doesn't get loaded and saved in all cases using the ConnectionConfiguration.load
and ConnectionConfiguration.update
method. Since ConnectionConfiguration.load
isn't used to load the configuration, some default values are not applied for undefined settings, like Quick Connect
. Consequently, when you edit the connection settings for a connection for which Quick Connect
is undefined, the checkbox is unchecked. But when the settings will be loaded during the connection, it will actually be true
. So the settings page is not the exact reflect of the actual settings in this case 😉
Using ConnectionConfiguration
's load
and update
will also simplify the connection settings page code a little bit and remove some redundant code.
@sebjulliand I see the problem and is on it... |
@sebjulliand The initialization problem in settings view is now fixed - please test thoroughly, since this is not a trivial code rewrite. |
@worksofliam It would be nice to have your eyes on this as well. |
@chrjorgensen Expect a test tonight (my tonight!) 👍 |
@worksofliam During my own tests I noticed that the fields I also noticed that |
@chrjorgensen I had a quick review and I think the whole idea of restarting can be removed now - you're right. I would need to confirm this for |
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.
The code is good and it works fine.
There is just one thing that needs to be fixed in my opinion, and we'll be good to merge!
Co-authored-by: Sébastien Julliand <sebjulliand@gmail.com>
@sebjulliand Suggestion has been accepted! 😉 |
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'm all for it!
@worksofliam I'll let you make your round of tests and merge if you're OK with it.
@@ -119,7 +120,8 @@ export namespace ConnectionConfiguration { | |||
debugIsSecure: (parameters.debugIsSecure === true), | |||
debugUpdateProductionFiles: (parameters.debugUpdateProductionFiles === true), | |||
debugEnableDebugTracing: (parameters.debugEnableDebugTracing === true), | |||
readOnlyMode: (parameters.readOnlyMode === true) | |||
readOnlyMode: (parameters.readOnlyMode === true), | |||
quickConnect: (parameters.quickConnect === true || parameters.quickConnect === undefined) |
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 tested this and it shows that Quick Connect will be on by default.
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.
@worksofliam Yeah, Quick Connect
was changed to be the default behavior with the setting available for the user to opt-out - per our discussion two weeks ago. Hope this is okay?
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.
Code looks good, but the 'Connect and Reload' right click option doesn't work as expected. Seems like the UI isn't updating after the connection is made?
Video uploading here: https://youtu.be/wntqwrjuFdM
@worksofliam I see that - looking into it... |
@worksofliam I'm glad I asked you to have a look and do some testing! 😃 There were a problem with two optional parameters to It should have been fixed now, please retest... |
Oh that's right. That was the It's good you pinpointed it! Now it makes me think that when we start having a few options like that, especially a succession of optional ones, we should gather them in an object to avoid this kind of issues and prevent "merge messes" 😅 //For example this...
async connect(connectionObject: ConnectionData, reconnecting?: boolean, reloadServerSettings: boolean = false) {
...
}
//...could become this
async connect(connectionObject: ConnectionData, options?:{reconnecting?: boolean, reloadServerSettings?: boolean}) {
...
} Not for today but definitely something way may keep in mind 😉 |
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.
Connect to reload cache works fine now.
Disconnecting and reconnecting manually with quick connect on works as expected.
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.
Yup, looks like it is working as expected now. I really like this feature - thanks for your hard work @chrjorgensen!
I will give you the pleasure of merging.
Thanks @worksofliam and @sebjulliand |
Changes
This PR will add a
Quick Connect
setting in the connection configuration to speed up connecting to the system:When selected, the following server settings are taken from the previous connection to the system:
These values are stored in connection storage on each connection to the system. So if no previous connection has been done, even though the
Quick Connect
is checked, all settings will be retrieved from the server and stored in the connection configuration to be used on the next connection.This setting is active by default. The user can disable it permanently in the configuration, or the user can reload all settings from server into cache by right-clicking on the connection and select
Connect and Reload Server Settings
.If the remote feature keys do not match the keys in the cache, the remote features will be checked on the server disregarding this setting.
For more information, see issue #1122.
Checklist