mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
76a2cf3569
Summary: Changelog: [Internal] * Refactor release automation so it doesn't use intermediate tags to trigger the release workflow. Now, we POST to CircleCI's ["trigger pipeline" API](https://circleci.com/docs/api/v2/#operation/triggerPipeline) * This does have the con of needing to give CircleCI project permission for whoever wants to run a release as you'll need a token to trigger * See related discussion: https://github.com/reactwg/react-native-releases/discussions/7#discussioncomment-1836420 Description of changes: * Changes to config.yml allow us to use our POST data to trigger a certain workflow. There is no direct API to trigger a workflow, CircleCI only has an API to trigger pipelines, so the suggestion is to leverage conditionals: https://support.circleci.com/hc/en-us/articles/360050351292-How-to-trigger-a-workflow-via-CircleCI-API-v2 * Update `bump-oss-version` to make the api call -- the instructions for running a release are still the same: https://github.com/facebook/react-native/wiki/Release-Process#creating-0minor0-rc0 * Would be good to make this a yarn script as tido64 mentioned * Remove unused utilities now that we don't use intermediate tags like `publish-...` Pull Request resolved: https://github.com/facebook/react-native/pull/32937 Test Plan: Have this on a Github branch and tried this out locally: ## Running release script Running the bump-oss script (I had to hack it locally to be allowed to run on a non-release branch): {F694804729} * Link to resulting workflow: https://app.circleci.com/pipelines/github/facebook/react-native/11836 -- you can [verify that the parameters are the same as I passed](https://app.circleci.com/pipelines/github/facebook/react-native/11836/workflows/59ac0c86-5fe3-4d7a-80e9-c61129d49e9f/jobs/232388?invite=true#step-106-2) ## Other attempts triggering this workflow Notice that when I tried to run it on an actual release-branch (0.67-stable) but because the `config.yml` changes aren't on that branch, the job faisl | {F694804321} | ## Verifying the right workflows trigger on a regular push * Notice that the workflows "analysis" and "test" are still triggered on push (ie, the `unless:` clause isn't messing things up) {F694804320} Reviewed By: sota000 Differential Revision: D33715336 Pulled By: lunaleaps fbshipit-source-id: 82672d6d50768015bdfc9f4ea4d22aa801b84f06
128 lines
4.0 KiB
JavaScript
128 lines
4.0 KiB
JavaScript
/**
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @format
|
|
*/
|
|
|
|
const {
|
|
parseVersion,
|
|
isTaggedLatest,
|
|
isReleaseBranch,
|
|
} = require('../version-utils');
|
|
|
|
let execResult = null;
|
|
jest.mock('shelljs', () => ({
|
|
exec: () => {
|
|
return {
|
|
stdout: execResult,
|
|
};
|
|
},
|
|
}));
|
|
|
|
describe('version-utils', () => {
|
|
describe('isReleaseBranch', () => {
|
|
it('should identify as release branch', () => {
|
|
expect(isReleaseBranch('v0.66-stable')).toBe(true);
|
|
expect(isReleaseBranch('0.66-stable')).toBe(true);
|
|
expect(isReleaseBranch('made-up-stuff-stable')).toBe(true);
|
|
});
|
|
it('should not identify as release branch', () => {
|
|
expect(isReleaseBranch('main')).toBe(false);
|
|
expect(isReleaseBranch('pull/32659')).toBe(false);
|
|
});
|
|
});
|
|
describe('isTaggedLatest', () => {
|
|
it('it should identify commit as tagged `latest`', () => {
|
|
execResult = '6c19dc3266b84f47a076b647a1c93b3c3b69d2c5\n';
|
|
expect(isTaggedLatest('6c19dc3266b84f47a076b647a1c93b3c3b69d2c5')).toBe(
|
|
true,
|
|
);
|
|
});
|
|
it('it should not identify commit as tagged `latest`', () => {
|
|
execResult = '6c19dc3266b84f47a076b647a1c93b3c3b69d2c5\n';
|
|
expect(isTaggedLatest('6c19dc3266b8')).toBe(false);
|
|
});
|
|
});
|
|
|
|
describe('parseVersion', () => {
|
|
it('should throw error if invalid match', () => {
|
|
function testInvalidVersion() {
|
|
parseVersion('<invalid version>');
|
|
}
|
|
expect(testInvalidVersion).toThrowErrorMatchingInlineSnapshot(
|
|
`"You must pass a correctly formatted version; couldn't parse <invalid version>"`,
|
|
);
|
|
});
|
|
|
|
it('should parse pre-release version with .', () => {
|
|
const {version, major, minor, patch, prerelease} =
|
|
parseVersion('0.66.0-rc.4');
|
|
expect(version).toBe('0.66.0-rc.4');
|
|
expect(major).toBe('0');
|
|
expect(minor).toBe('66');
|
|
expect(patch).toBe('0');
|
|
expect(prerelease).toBe('rc.4');
|
|
});
|
|
|
|
it('should parse pre-release version with -', () => {
|
|
const {version, major, minor, patch, prerelease} =
|
|
parseVersion('0.66.0-rc-4');
|
|
expect(version).toBe('0.66.0-rc-4');
|
|
expect(major).toBe('0');
|
|
expect(minor).toBe('66');
|
|
expect(patch).toBe('0');
|
|
expect(prerelease).toBe('rc-4');
|
|
});
|
|
|
|
it('should parse stable version', () => {
|
|
const {version, major, minor, patch, prerelease} = parseVersion('0.66.0');
|
|
expect(version).toBe('0.66.0');
|
|
expect(major).toBe('0');
|
|
expect(minor).toBe('66');
|
|
expect(patch).toBe('0');
|
|
expect(prerelease).toBeUndefined();
|
|
});
|
|
it('should parse pre-release version from tag', () => {
|
|
const {version, major, minor, patch, prerelease} =
|
|
parseVersion('v0.66.1-rc.4');
|
|
expect(version).toBe('0.66.1-rc.4');
|
|
expect(major).toBe('0');
|
|
expect(minor).toBe('66');
|
|
expect(patch).toBe('1');
|
|
expect(prerelease).toBe('rc.4');
|
|
});
|
|
|
|
it('should parse stable version from tag', () => {
|
|
const {version, major, minor, patch, prerelease} =
|
|
parseVersion('v0.66.0');
|
|
expect(version).toBe('0.66.0');
|
|
expect(major).toBe('0');
|
|
expect(minor).toBe('66');
|
|
expect(patch).toBe('0');
|
|
expect(prerelease).toBeUndefined();
|
|
});
|
|
|
|
it('should parse nightly fake version', () => {
|
|
const {version, major, minor, patch, prerelease} = parseVersion('0.0.0');
|
|
expect(version).toBe('0.0.0');
|
|
expect(major).toBe('0');
|
|
expect(minor).toBe('0');
|
|
expect(patch).toBe('0');
|
|
expect(prerelease).toBeUndefined();
|
|
});
|
|
|
|
it('should parse dryrun fake version', () => {
|
|
const {version, major, minor, patch, prerelease} =
|
|
parseVersion('1000.0.0');
|
|
expect(version).toBe('1000.0.0');
|
|
expect(major).toBe('1000');
|
|
expect(minor).toBe('0');
|
|
expect(patch).toBe('0');
|
|
expect(prerelease).toBeUndefined();
|
|
});
|
|
});
|
|
});
|