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

Download and extract go-sqlcmd before main action #108

Merged
merged 6 commits into from
Aug 8, 2022
Merged

Conversation

zijchen
Copy link
Contributor

@zijchen zijchen commented Jul 20, 2022

  • Adds some setup code to download and extract go-sqlcmd based on platform
  • Adds it to the runner's tool cache for fast lookup in between job runs
  • Also adds it to PATH so we can call sqlcmd directly from the main action

@zijchen zijchen temporarily deployed to Automation test July 20, 2022 00:18 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 00:18 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 00:18 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 00:18 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 00:18 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 00:18 Inactive
@zijchen zijchen changed the base branch from master to v2 July 20, 2022 00:18
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 00:32 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 00:32 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 00:32 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 00:32 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 00:32 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 00:32 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 20:37 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 20:37 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 20:38 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 20:38 Inactive
@zijchen zijchen temporarily deployed to Automation test July 20, 2022 20:38 Inactive
@zijchen zijchen marked this pull request as ready for review July 20, 2022 20:43
@zijchen
Copy link
Contributor Author

zijchen commented Jul 20, 2022

@shueybubbles I can't add you as a reviewer for some reason, but could you take a look at this PR? This adds support to download go-sqlcmd from your Github page before anything else is run. Code to hook it up will be added later.

@shueybubbles
Copy link
Contributor

We have sqlcmd available in yum and apt-get etc now, would using those be preferable?


Refers to: src/Setup.ts:47 in 5466044. [](commit_id = 5466044, deletion_comment = False)

Copy link
Contributor

@shueybubbles shueybubbles left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

:shipit:

@zijchen
Copy link
Contributor Author

zijchen commented Jul 20, 2022

We have sqlcmd available in yum and apt-get etc now, would using those be preferable?

Refers to: src/Setup.ts:47 in 5466044. [](commit_id = 5466044, deletion_comment = False)

I did see that, but I just went with the download URL since we need to use it for Windows anyway, and for Linux it's just a matter of changing the URL.

src/Setup.ts Show resolved Hide resolved
src/Setup.ts Show resolved Hide resolved
src/Setup.ts Show resolved Hide resolved
@github-actions
Copy link

github-actions bot commented Aug 5, 2022

This PR is idle because it has been open for 14 days with no activity.

@github-actions github-actions bot added the idle Inactive for 14 days label Aug 5, 2022
src/Setup.ts Show resolved Hide resolved
export const sqlcmdVersion = '0.8.1';

export default class Setup {

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit: extra line

@zijchen zijchen merged commit a08bea3 into v2 Aug 8, 2022
@zijchen zijchen deleted the zijchen/go-sqlcmd branch August 8, 2022 17:23
zijchen added a commit that referenced this pull request Sep 28, 2022
* v2 - Use tedious mssql module instead of sqlcmd (#96)

* Use tedious mssql library instead of sqlcmd

* Fix mssql connection

* Fix SqlUtils tests

* Use config instead of connection string

* Replace conn string builder with mssql config

* Connect to master db

* Restore connection string validation regex

* PR comments, fix error handling

* Update main.js

* Use try catch for error handling

* Fix typo

* v2 - Change script action from sqlcmd to mssql query (#99)

* Change script action from sqlcmd to mssql query

* Update action.yml

* Fully qualify Table1 in sql script

* Add more debug logging

* Clone config before changing db to master

* Cleanup

* Set TEST_DB name before cleanup

* Use runner.temp

* Always cleanup

* PR comments

* Fix database cleanup step in pr-check (#101)

* Debug script contents

* Fix sed command

* Remove debug

* v2 - Add support for AAD password, AAD default, and AAD service principal auth (#100)

* Use tedious mssql library instead of sqlcmd

* Fix mssql connection

* Fix SqlUtils tests

* Use config instead of connection string

* Replace conn string builder with mssql config

* Connect to master db

* Restore connection string validation regex

* AAD auth

* Add support for client and tenant IDs

* Add more debug messaging

* Fix connection string find array

* Make client-id and tenant-id action inputs

* Fix error handling

* More fixes

* Use try catch instead

* Add tests to pr-check.yml

* Change script action from sqlcmd to mssql query

* Update action.yml

* Fully qualify Table1 in sql script

* Add more debug logging

* Clone config before changing db to master

* Cleanup

* Set TEST_DB name before cleanup

* Use runner.temp

* Always cleanup

* Add tests for different auth types

* Mask tenant and client IDs

* Add AAD password test to pr-check.yml

* Fix yaml

* Limit max-parallel to 2

* Add test for service principal

* PR comments

* Fix typo

* Cleanup sqlcmd references (#102)

* Retry connection with user DB if master connection fails (#104)

* Retry with DB connection if master fails

* Add tests

* Add ConnectionResult interface

* Add missing doc comment

* PR comments

* PR Comments

* Download and extract go-sqlcmd before main action (#108)

* Add setup script to download go-sqlcmd

* Add sqlcmd call to pr-check.yml

* Add bz2 specific extract tar

* Move setup code to main

* Move setup code to main

* Fix casing of Setup.ts

* Use go-sqlcmd for script action (#113)

* call go-sqlcmd for script action

* Fix auth options not flowing through

* Add test cases

* Restore sqlcmd variable in cleanup script

* Fix pr-check cleanup

* Undo changes to pr-check.yml

* Undo pr-check.yml changes

* PR comments

* Change inputs (#105)

* Update SQL API version to 2021-11-01 (#117)

* Add support for Script, DeployReport, and DriftReport (#106)

* Change inputs

* Add other publish like actions

* Add tests

* Fix test

* PR comments

* Add mockReturnValue for auth type test

* Remove MacOS from ci.yml

* links to documentation on each argument type (#123)

* v2 - Remove client-id and tenant-id as inputs (#124)

* Set tenantId and clientId only when passed in

* Default to empty string

* Default to empty string

* Replace mssql call with go-sqlcmd query

* Capture sqlcmd error message

* Add more debug

* Capture stdout too

* Fix config passing

* Completely remove client-id and tenant-id

* cleanup

* Update sqlcmd query

* adding connection string format to docs (#138)

adding connection string format to docs

Co-authored-by: Drew Skwiers-Koballa <dzsquared@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
idle Inactive for 14 days
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants