Feat: editorial workflow bitbucket gitlab (#3014)

* refactor: typescript the backends

* feat: support multiple files upload for GitLab and BitBucket

* fix: load entry media files from media folder or UI state

* chore: cleanup log message

* chore: code cleanup

* refactor: typescript the test backend

* refactor: cleanup getEntry unsued variables

* refactor: moved shared backend code to lib util

* chore: rename files to preserve history

* fix: bind readFile method to API classes

* test(e2e): switch to chrome in cypress tests

* refactor: extract common api methods

* refactor: remove most of immutable js usage from backends

* feat(backend-gitlab): initial editorial workflow support

* feat(backend-gitlab): implement missing workflow methods

* chore: fix lint error

* feat(backend-gitlab): support files deletion

* test(e2e): add gitlab cypress tests

* feat(backend-bitbucket): implement missing editorial workflow methods

* test(e2e): add BitBucket backend e2e tests

* build: update node version to 12 on netlify builds

* fix(backend-bitbucket): extract BitBucket avatar url

* test: fix git-gateway AuthenticationPage test

* test(e2e): fix some backend tests

* test(e2e): fix tests

* test(e2e): add git-gateway editorial workflow test

* chore: code cleanup

* test(e2e): revert back to electron

* test(e2e): add non editorial workflow tests

* fix(git-gateway-gitlab): don't call unpublishedEntry in simple workflow

gitlab git-gateway doesn't support editorial workflow APIs yet. This change makes sure not to call them in simple workflow

* refactor(backend-bitbucket): switch to diffstat API instead of raw diff

* chore: fix test

* test(e2e): add more git-gateway tests

* fix: post rebase typescript fixes

* test(e2e): fix tests

* fix: fix parsing of content key and add tests

* refactor: rename test file

* test(unit): add getStatues unit tests

* chore: update cypress

* docs: update beta docs
This commit is contained in:
Erez Rokah
2020-01-15 00:15:14 +02:00
committed by Shawn Erquhart
parent 4ff5bc2ee0
commit 6f221ab3c1
251 changed files with 70910 additions and 15974 deletions

View File

@ -20,6 +20,14 @@ const {
setupGitGatewayTest,
teardownGitGatewayTest,
} = require('./gitGateway');
const { setupGitLab, teardownGitLab, setupGitLabTest, teardownGitLabTest } = require('./gitlab');
const {
setupBitBucket,
teardownBitBucket,
setupBitBucketTest,
teardownBitBucketTest,
} = require('./bitbucket');
const { copyBackendFiles } = require('../utils/config');
module.exports = async (on, config) => {
@ -37,6 +45,12 @@ module.exports = async (on, config) => {
case 'git-gateway':
result = await setupGitGateway(options);
break;
case 'gitlab':
result = await setupGitLab(options);
break;
case 'bitbucket':
result = await setupBitBucket(options);
break;
}
return result;
@ -52,6 +66,12 @@ module.exports = async (on, config) => {
case 'git-gateway':
await teardownGitGateway(taskData);
break;
case 'gitlab':
await teardownGitLab(taskData);
break;
case 'bitbucket':
await teardownBitBucket(taskData);
break;
}
console.log('Restoring defaults');
@ -70,6 +90,12 @@ module.exports = async (on, config) => {
case 'git-gateway':
await setupGitGatewayTest(taskData);
break;
case 'gitlab':
await setupGitLabTest(taskData);
break;
case 'bitbucket':
await setupBitBucketTest(taskData);
break;
}
return null;
@ -86,6 +112,12 @@ module.exports = async (on, config) => {
case 'git-gateway':
await teardownGitGatewayTest(taskData);
break;
case 'gitlab':
await teardownGitLabTest(taskData);
break;
case 'bitbucket':
await teardownBitBucketTest(taskData);
break;
}
return null;
@ -96,20 +128,11 @@ module.exports = async (on, config) => {
if (browser.name === 'chrome') {
// to allows usage of a mock proxy
args.push('--ignore-certificate-errors');
return args;
}
if (browser.name === 'electron') {
// to allows usage of a mock proxy
args['ignore-certificate-errors'] = true;
// https://github.com/cypress-io/cypress/issues/2102
args.push('-disable-gpu');
if (browser.isHeaded) {
args['width'] = 1200;
args['height'] = 1200;
args.push('--window-size=1200,1200');
} else {
args['width'] = 1200;
args['height'] = process.platform === 'darwin' ? 1178 : 1200;
args.push('--window-size=1200,1077');
}
return args;