Skip to content

Commit

Permalink
Merge pull request #390 from slingdata-io/1.2.21
Browse files Browse the repository at this point in the history
1.2.21
  • Loading branch information
flarco authored Oct 21, 2024
2 parents 2b4c938 + 1c4904e commit 73216e1
Show file tree
Hide file tree
Showing 72 changed files with 1,147 additions and 777 deletions.
12 changes: 7 additions & 5 deletions .github/workflows/build-dev.yml
Original file line number Diff line number Diff line change
Expand Up @@ -34,19 +34,21 @@ jobs:
id: get_version
run: |
VERSION="${GITHUB_REF##*/}.dev"
echo "VERSION -> $VERSION"
DATE=$(date +%F)
VERSION=$(echo $VERSION | sed 's/v//')
VERSION=$(echo $VERSION | sed 's/^v//')
echo "VERSION -> $VERSION"
VERSION="$VERSION/$DATE"
echo "VERSION -> $VERSION"
echo ::set-output name=VERSION::$VERSION
echo "VERSION=$VERSION" >> $GITHUB_OUTPUT
- id: step1
name: Build
env:
VERSION: ${{ steps.get_version.outputs.VERSION }}
run: |
bash scripts/build.sh
echo ::set-output name=version::$VERSION
echo "VERSION=$VERSION" >> $GITHUB_OUTPUT
release:
if: "! (contains(github.event.inputs.build_only, 'true'))"
Expand Down Expand Up @@ -77,7 +79,7 @@ jobs:
echo "JOB_CONTEXT -> $JOB_CONTEXT"
echo "MATRIX_CONTEXT -> $MATRIX_CONTEXT"
echo "RUNNER_CONTEXT -> $RUNNER_CONTEXT"
echo "VERSION -> $VERSION"
echo "VERSION -> ${{ needs.build.outputs.VERSION }}"
- name: Set up GoLang
uses: actions/setup-go@v3
Expand All @@ -86,7 +88,7 @@ jobs:
cache: false

- name: Load Secrets
uses: flarco/infisical-action@v2
uses: flarco/infisical-action@v3
with:
version: 0.28.1
client_id: ${{ secrets.INFISICAL_CLIENT_ID }}
Expand Down
8 changes: 4 additions & 4 deletions .github/workflows/build-release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ jobs:
cache: false

- name: Load Secrets
uses: flarco/infisical-action@v2
uses: flarco/infisical-action@v3
with:
version: 0.28.1
client_id: ${{ secrets.INFISICAL_CLIENT_ID }}
Expand Down Expand Up @@ -129,7 +129,7 @@ jobs:
cache: true

- name: Load Secrets
uses: flarco/infisical-action@v2
uses: flarco/infisical-action@v3
with:
version: 0.28.1
client_id: ${{ secrets.INFISICAL_CLIENT_ID }}
Expand Down Expand Up @@ -179,7 +179,7 @@ jobs:
cache: false

- name: Load Secrets
uses: flarco/infisical-action@v2
uses: flarco/infisical-action@v3
with:
version: 0.28.1
client_id: ${{ secrets.INFISICAL_CLIENT_ID }}
Expand Down Expand Up @@ -234,7 +234,7 @@ jobs:
cache: false

- name: Load Secrets
uses: flarco/infisical-action@v2
uses: flarco/infisical-action@v3
with:
version: 0.28.1
client_id: ${{ secrets.INFISICAL_CLIENT_ID }}
Expand Down
4 changes: 2 additions & 2 deletions .github/workflows/build-test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -32,14 +32,14 @@ jobs:
cache: false

- name: Load Secrets
uses: flarco/infisical-action@v2
uses: flarco/infisical-action@v3
with:
version: 0.28.1
client_id: ${{ secrets.INFISICAL_CLIENT_ID }}
client_secret: ${{ secrets.INFISICAL_CLIENT_SECRET }}

- name: Load Secrets (dbio)
uses: flarco/infisical-action@v2
uses: flarco/infisical-action@v3
with:
version: 0.28.1
client_id: ${{ secrets.INFISICAL_CLIENT_ID }}
Expand Down
8 changes: 4 additions & 4 deletions .github/workflows/test-docker-build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ jobs:
cache: false

- name: Load Secrets
uses: flarco/infisical-action@v2
uses: flarco/infisical-action@v3
with:
version: 0.28.1
client_id: ${{ secrets.INFISICAL_CLIENT_ID }}
Expand Down Expand Up @@ -69,7 +69,7 @@ jobs:
cache: true

- name: Load Secrets
uses: flarco/infisical-action@v2
uses: flarco/infisical-action@v3
with:
version: 0.28.1
client_id: ${{ secrets.INFISICAL_CLIENT_ID }}
Expand Down Expand Up @@ -119,7 +119,7 @@ jobs:
cache: false

- name: Load Secrets
uses: flarco/infisical-action@v2
uses: flarco/infisical-action@v3
with:
version: 0.28.1
client_id: ${{ secrets.INFISICAL_CLIENT_ID }}
Expand Down Expand Up @@ -162,7 +162,7 @@ jobs:
cache: false

- name: Load Secrets
uses: flarco/infisical-action@v2
uses: flarco/infisical-action@v3
with:
version: 0.28.1
client_id: ${{ secrets.INFISICAL_CLIENT_ID }}
Expand Down
1 change: 1 addition & 0 deletions .goreleaser.notes.md
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@

See https://github.com/slingdata-io/sling-cli/ for more details.
160 changes: 70 additions & 90 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -183,108 +183,88 @@ Here are the links of the official development builds, which are the latest buil

Then you should be able to run `sling --help` from command line.

## Running a Extract-Load Task

### CLI
## Contributing

```shell
sling run --src-conn POSTGRES_URL --src-stream myschema.mytable \
--tgt-conn SNOWFLAKE_URL --tgt-object yourschema.yourtable \
--mode full-refresh
```
We welcome contributions to improve Sling! Here are some guidelines to help you get started.

Or passing a yaml/json string or file
### Branch Naming Convention

```shell
sling run -c '
source:
conn: $POSTGRES_URL
stream: myschema.mytable
target:
conn: $SNOWFLAKE_URL
object: yourschema.yourtable
mode: full-refresh
'
# OR
sling run -c /path/to/config.json
When creating a new branch for your contribution, please use the following naming convention:

- `feature/your-feature-name` for new features
- `bugfix/issue-description` for bug fixes
- `docs/update-description` for documentation updates

### Testing Guidelines

Sling has three main test suites: Database, File and CLI. When contributing, please ensure that your changes pass the relevant tests.

#### Running Tests

To run the full test suite, run below. However you'd need to define all the needed connections as shown [here](https://github.com/slingdata-io/sling-cli/blob/main/cmd/sling/sling_test.go#L52-L83), so it's recommended to target specific tests instead.

```sh
./scripts/build.sh
./scripts/test.sh
```

### From Lib
#### Targeting Specific Tests

```go
package main
You can target specific tests or suites using environment variables:

import (
"log"
1. Database Suite:
```sh
cd cmd/sling
go test -v -run TestSuiteDatabasePostgres # run all Postgres tests
TESTS="1-3" go test -v -run TestSuiteDatabasePostgres # run Postgres tests 1, 2, 3
```

"github.com/slingdata-io/sling-cli/core/sling"
)
2. File Suite:
```sh
cd cmd/sling
go test -v -run TestSuiteFileS3 # run all S3 tests
TESTS="1,2,3" go test -v -run TestSuiteFileS3 # run S3 tests 1, 2, 3
```

func main() {
// cfgStr can be JSON or YAML
cfgStr := `
source:
conn: $POSTGRES_URL
stream: myschema.mytable
3. CLI Suite:
```sh
cd cmd/sling
export SLING_BIN=../../sling
go test -v -run TestCLI # run all CLI tests
TESTS="31+" go test -v -run TestCLI # run CLI tests 31 and all subsequent tests
```

target:
conn: $SNOWFLAKE_URL
object: yourschema.yourtable
You can specify individual test numbers, ranges, or use the '+' suffix to run all tests from a certain number:

mode: full-refresh
`
cfg, err := sling.NewConfig(cfgStr)
if err != nil {
log.Fatal(err)
}
- `TESTS="1,2,3"`: Run tests 1, 2, and 3
- `TESTS="1-5"`: Run tests 1 through 5
- `TESTS="3+"`: Run test 3 and all subsequent tests

err = sling.Sling(cfg)
if err != nil {
log.Fatal(err)
}
}
#### Test Suites Overview

```
1. **Database Suite**: Tests database-related functionality.
- Located in: `cmd/sling/sling_test.go`
- Configuration: `cmd/sling/tests/suite.db.template.tsv`

## Config Schema

An example. Put this in https://jsonschema.net/

`--src-conn`/`source.conn` and `--tgt-conn`/`target.conn` can be a name or URL of a folder:
- `MY_PG` (connection ref in db, profile or env)
- `$MY_PG` (connection ref in env)
- `postgresql://user:[email protected]:5432/database`
- `s3://my_bucket/my_folder/file.csv`
- `gs://my_google_bucket/my_folder/file.json`
- `file:///tmp/my_folder/file.csv` (local storage)

`--src-stream`/`source.stream` can be an object name to stream from:
- `TABLE1`
- `SCHEMA1.TABLE2`
- `OBJECT_NAME`
- `select * from SCHEMA1.TABLE3`
- `/path/to/file.sql` (if source conn is DB)

`--tgt-object`/`target.object` can be an object name to write to:
- `TABLE1`
- `SCHEMA1.TABLE2`

### Example as JSON

```json
{
"source": {
"conn": "MY_PG_URL",
"stream": "select * from my_table",
"options": {}
},
"target": {
"conn": "s3://my_bucket/my_folder/new_file.csv",
"options": {
"header": false
}
}
}
```
2. **File Suite**: Tests file system operations.
- Located in: `cmd/sling/sling_test.go`
- Configuration: `cmd/sling/tests/suite.file.template.tsv`

3. **CLI Suite**: Tests command-line interface functionality.
- Located in: `cmd/sling/sling_cli_test.go`
- Configuration: `cmd/sling/tests/suite.cli.tsv`

### Adding New Tests

When introducing new features or addressing bugs, it's essential to incorporate relevant tests, focusing mainly on the CLI suite file located at `cmd/sling/suite.cli.tsv`. The database and file suites serve as templates applicable across all connectors, making them more sensitive to modifications. Therefore, any changes to these suites will be managed internally.

When adding new test entries in the CLI suite file, feel free to create a new replication file in folder `cmd/sling/tests/replications`, or a corresponding source file in the `cmd/sling/tests/files` directory. Also include the expected output or the number of expected rows/streams in the new test entry.

### Pull Request Process

1. Ensure your code adheres to the existing style and passes all tests.
2. Update the README.md with details of changes to the interface, if applicable.
3. Create a Pull Request with a clear title and description.

Thank you for contributing to Sling!
2 changes: 1 addition & 1 deletion cmd/sling/sling_cli.go
Original file line number Diff line number Diff line change
Expand Up @@ -354,7 +354,7 @@ func init() {
cliUpdate.Make().Add()

if projectID == "" {
projectID = os.Getenv("GITHUB_REPOSITORY_ID")
projectID = os.Getenv("SLING_PROJECT_ID")
}
}

Expand Down
4 changes: 2 additions & 2 deletions cmd/sling/sling_conns.go
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,7 @@ func processConns(c *g.CliSC) (ok bool, err error) {
return ok, g.Error(err, "cannot parse query")
}

if len(database.ParseSQLMultiStatements(query)) == 1 && (!sQuery.IsQuery() || strings.Contains(strings.ToLower(query), "select") || g.In(conn.Connection.Type, dbio.TypeDbPrometheus, dbio.TypeDbMongoDB)) {
if len(database.ParseSQLMultiStatements(query)) == 1 && (!sQuery.IsQuery() || (strings.Contains(strings.ToLower(query), "select") && !strings.Contains(strings.ToLower(query), "insert")) || g.In(conn.Connection.Type, dbio.TypeDbPrometheus, dbio.TypeDbMongoDB)) {

data, err := dbConn.Query(sQuery.Select(100, 0))
if err != nil {
Expand Down Expand Up @@ -174,7 +174,7 @@ func processConns(c *g.CliSC) (ok bool, err error) {

ok, err = entries.Test(name)
if err != nil {
err = g.Error(err, "could not test %s (See https://docs.slingdata.io/sling-cli/environment)", name)
err = g.Error(err, "could not test %s", name)
}

if asJSON {
Expand Down
Loading

0 comments on commit 73216e1

Please sign in to comment.