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

[Bug 1473091] Migrate mozilla/redash to circleci 2.0 #488

Merged
merged 2 commits into from
Aug 15, 2018

Conversation

haroldwoo
Copy link

No description provided.

@jasonthomas
Copy link
Member

This looks good to me. Upstream has a PR for CircleCI 2.0 support getredash#2672 which includes a lot more integration tests. I think once upstream is merged we should pull those tests into this config. We probably still need to maintain a different CircleCI configuration due to our deployment model. CCing @jezdez for input.

@haroldwoo
Copy link
Author

How often do we merge with upstream? It does make sense to pull those tests into here once we do, but we can cross that bridge later?

only: /^m[0-9]+(\.[0-9]+)?$/
branches:
only:
# Do we only care about milestone tags on these branches?
Copy link
Author

Choose a reason for hiding this comment

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

i'm not sure what branches we care about deploying milestone tags?

Choose a reason for hiding this comment

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

Tags are just pointers to a commit and have nothing to do with branches. I think the branches are supposed to be set to ignore based on my reading here.

@jezdez
Copy link

jezdez commented Aug 9, 2018

@jasonthomas Oh dang, this seems like some overlap here, since @jrbenny35 has been working on this in #439 as well. I don't mind which solution is chosen and I have way too little experience with Circle 2.0 to make the call.

But we need to make sure that the solution here is not completely different from what will soon (given the deadline) land upstream. Upstream there is still a question whether the redash-ui-tests (that @jrbenny35 and @hackebrot have created on our side) should be included upstream (my gut says no since the tests aren't ready yet and we haven't full buy-in from upstream, but I hope to have the main maintainer reply to our question about it).

@haroldwoo @jasonthomas Could you talk with @jrbenny35 about how we can find a common denominator between the efforts and solve the issue for both our fork and upstream? We strive to reduce the divergence from upstream as much as possible given our current work of porting our changes upstream after all and eventually plan to have little or no modification in a fork (dream scenario: we deploy from a separate repo that just contains inherited Docker info and extended Circle config).

@jezdez
Copy link

jezdez commented Aug 9, 2018

Thank you all for your effort of course, much appreciated!

@haroldwoo
Copy link
Author

The purpose of this PR was simply to upgrade our existing circle code from 1.0 to 2.0 before 1.0 deprecation. When/If the other PR lands upstream, we can consolidate our circle builds then. Does this sound fair?

@jezdez
Copy link

jezdez commented Aug 13, 2018

@haroldwoo Be that as it may, merging this will create more work than to just find a common ground since @jrbenny35 is a Mozilla test engineer working on this anyway.

@jrbenny35 Do you think you can look through this and see if this is compatible with your approach?

@jezdez
Copy link

jezdez commented Aug 13, 2018

Disregard what I said in my last comment, I spoke with @haroldwoo more about this on IRC and he suggested to merge this now and then wait for the outcome from the upstream PR (getredash#2672) and deal with the result when merging upstream into our fork at the next occasion.

Copy link

@jezdez jezdez left a comment

Choose a reason for hiding this comment

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

Just a few questions before we merge this :)

printf '{"commit":"%s","version":"%s","source":"https://github.com/%s/%s","build":"%s"}\n' "$CIRCLE_SHA1" "$CIRCLE_TAG" "$CIRCLE_PROJECT_USERNAME" "$CIRCLE_PROJECT_REPONAME" "$CIRCLE_BUILD_URL" > version.json
- run:
command: docker build -t app:build .
no_output_timeout: 20m
Copy link

Choose a reason for hiding this comment

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

I'm trying to understand the purpose of the build job and can't find an equivalent in the old config. It's run for every tag and all branches except gh-pages IIUC. Is this just to make sure the image build succeeds?

Could we remove the writing of the version.json since it was abstracted away in the bin/deploy script for the other jobs?

Copy link
Author

Choose a reason for hiding this comment

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

Yes it's just to ensure that the image builds properly. I will remove the version.json for the build step

Copy link

Choose a reason for hiding this comment

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

Gotcha, thanks!

else
# Deploy a release tag...
./bin/deploy "rc"
fi
Copy link

Choose a reason for hiding this comment

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

Could we split the deploy job into two jobs deploy-master and deploy-rc (and update the workflows below) instead of having the shell script with the condition? That would make it more obvious in the Circle UI what's happening.

Copy link
Author

Choose a reason for hiding this comment

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

sure

Copy link

Choose a reason for hiding this comment

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

Thanks!

@jezdez jezdez merged commit 4f1d2ce into mozilla:master Aug 15, 2018
@jezdez jezdez added this to the 16 milestone Aug 15, 2018
@jezdez jezdez mentioned this pull request Aug 15, 2018
jezdez pushed a commit that referenced this pull request Aug 16, 2018
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502)
jezdez pushed a commit that referenced this pull request Sep 6, 2018
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502)
jezdez pushed a commit that referenced this pull request Nov 1, 2018
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502)
jezdez pushed a commit that referenced this pull request Dec 12, 2018
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502)
jezdez pushed a commit that referenced this pull request Dec 17, 2018
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502)
jezdez pushed a commit that referenced this pull request Mar 25, 2019
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502)

# Conflicts:
#	.circleci/config.yml
emtwo pushed a commit that referenced this pull request Jul 15, 2019
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Refs #13
Refs #37
emtwo pushed a commit that referenced this pull request Jul 17, 2019
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Refs #13
Refs #37
jezdez pushed a commit that referenced this pull request Aug 12, 2019
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Refs #13
Refs #37
jezdez pushed a commit that referenced this pull request Aug 14, 2019
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Refs #13
Refs #37
jezdez pushed a commit that referenced this pull request Aug 19, 2019
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Refs #13
Refs #37
washort pushed a commit that referenced this pull request Sep 16, 2019
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Refs #13
Refs #37
emtwo pushed a commit that referenced this pull request Nov 5, 2019
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Refs #13
Refs #37
jezdez pushed a commit that referenced this pull request Jan 16, 2020
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Disable test that tests the login page and the existence of the
remote auth link there. We override this functionality for user
experience reasons via redash-stmo and redirect from the login page
to the remote auth URL.

Refs #13
Refs #37
jezdez pushed a commit that referenced this pull request May 4, 2020
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Disable test that tests the login page and the existence of the
remote auth link there. We override this functionality for user
experience reasons via redash-stmo and redirect from the login page
to the remote auth URL.

Refs #13
Refs #37
jezdez pushed a commit that referenced this pull request May 14, 2020
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Disable test that tests the login page and the existence of the
remote auth link there. We override this functionality for user
experience reasons via redash-stmo and redirect from the login page
to the remote auth URL.

Refs #13
Refs #37
robhudson pushed a commit that referenced this pull request Jun 4, 2020
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Disable handlers test that tests the login page and the existence of the
remote auth link there. We override this functionality for user
experience reasons via redash-stmo and redirect from the login page to
the remote auth URL.

Update metrics test since our auth changes add a database call which
also gets timed, and therefore assert this was called only once fails.

Refs #13
Refs #37
emtwo pushed a commit that referenced this pull request Jul 14, 2020
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Disable handlers test that tests the login page and the existence of the
remote auth link there. We override this functionality for user
experience reasons via redash-stmo and redirect from the login page to
the remote auth URL.

Update metrics test since our auth changes add a database call which
also gets timed, and therefore assert this was called only once fails.

Refs #13
Refs #37
jezdez pushed a commit that referenced this pull request Oct 15, 2020
- Use new master / rc release release strategy (#440)
- Migrate Circle CI 2.0 (#488, #502, #923)
- Install redash-stmo.

In the long run we'll be able to install additional dependencies by
having an own Dockerfile to build images based on the Redash image
but that installs additional Python dependencies. But until we have
a fork with lots of changes ourselves we need to do it this way.

Redash-stmo contains the ability to hook up our own Dockerflow
library.

Disable handlers test that tests the login page and the existence of the
remote auth link there. We override this functionality for user
experience reasons via redash-stmo and redirect from the login page to
the remote auth URL.

Update metrics test since our auth changes add a database call which
also gets timed, and therefore assert this was called only once fails.

Refs #13
Refs #37
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

4 participants