mirror of
https://github.com/subosito/flutter-action.git
synced 2024-08-16 10:19:50 +02:00
add any channel
This commit is contained in:
parent
d141f1640a
commit
d8b5280c4b
3 changed files with 75 additions and 15 deletions
|
@ -113,5 +113,33 @@ describe('release tests', () => {
|
||||||
expect(result.rawVersion).toEqual('1.17.0-dev.5.0');
|
expect(result.rawVersion).toEqual('1.17.0-dev.5.0');
|
||||||
expect(result.downloadUrl).toContain('1.17.0-dev.5.0');
|
expect(result.downloadUrl).toContain('1.17.0-dev.5.0');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('channel: "any", version: "1.17.x"', async () => {
|
||||||
|
const result = await release.determineVersion('1.17.x', 'any', platform);
|
||||||
|
|
||||||
|
expect(result.version).toEqual('1.17.5');
|
||||||
|
expect(result.rawVersion).toEqual('1.17.5');
|
||||||
|
expect(result.downloadUrl).toContain('1.17.5');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('channel: "any", version: "1.19.x"', async () => {
|
||||||
|
const result = await release.determineVersion('1.19.x', 'any', platform);
|
||||||
|
|
||||||
|
expect(result.version).toEqual('1.19.0-5.0.pre');
|
||||||
|
expect(result.rawVersion).toEqual('1.19.0-5.0.pre');
|
||||||
|
expect(result.downloadUrl).toContain('1.19.0-5.0.pre');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('channel: "any", version: "1.19.0-4.x"', async () => {
|
||||||
|
const result = await release.determineVersion(
|
||||||
|
'1.19.0-4.x',
|
||||||
|
'any',
|
||||||
|
platform
|
||||||
|
);
|
||||||
|
|
||||||
|
expect(result.version).toEqual('1.19.0-4.3.pre');
|
||||||
|
expect(result.rawVersion).toEqual('1.19.0-4.3.pre');
|
||||||
|
expect(result.downloadUrl).toContain('1.19.0-4.3.pre');
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -13,15 +13,23 @@ export async function getFlutter(
|
||||||
const platform = release.getPlatform();
|
const platform = release.getPlatform();
|
||||||
const useMaster = channel == 'master';
|
const useMaster = channel == 'master';
|
||||||
|
|
||||||
const {version: selected, downloadUrl} = await release.determineVersion(
|
const {
|
||||||
|
version: selected,
|
||||||
|
downloadUrl,
|
||||||
|
channel: validatedChannel
|
||||||
|
} = await release.determineVersion(
|
||||||
version,
|
version,
|
||||||
useMaster ? 'dev' : channel,
|
useMaster ? 'dev' : channel,
|
||||||
platform
|
platform
|
||||||
);
|
);
|
||||||
|
|
||||||
|
if (channel !== validatedChannel) {
|
||||||
|
core.debug(`Channel was identifyed as ${validatedChannel}`);
|
||||||
|
}
|
||||||
|
|
||||||
let cleanver = useMaster
|
let cleanver = useMaster
|
||||||
? channel
|
? validatedChannel
|
||||||
: `${selected.replace('+', '-')}-${channel}`;
|
: `${selected.replace('+', '-')}-${validatedChannel}`;
|
||||||
|
|
||||||
let toolPath = tc.find('flutter', cleanver);
|
let toolPath = tc.find('flutter', cleanver);
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,13 @@ import * as semver from 'semver';
|
||||||
export const storageUrl =
|
export const storageUrl =
|
||||||
'https://storage.googleapis.com/flutter_infra/releases';
|
'https://storage.googleapis.com/flutter_infra/releases';
|
||||||
|
|
||||||
|
interface IFlutterData {
|
||||||
|
channel: string;
|
||||||
|
version: string;
|
||||||
|
rawVersion: string;
|
||||||
|
downloadUrl: string;
|
||||||
|
}
|
||||||
|
|
||||||
interface IFlutterChannel {
|
interface IFlutterChannel {
|
||||||
[key: string]: string;
|
[key: string]: string;
|
||||||
beta: string;
|
beta: string;
|
||||||
|
@ -42,7 +49,7 @@ export async function determineVersion(
|
||||||
version: string,
|
version: string,
|
||||||
channel: string,
|
channel: string,
|
||||||
platform: string
|
platform: string
|
||||||
): Promise<{version: string; rawVersion: string; downloadUrl: string}> {
|
): Promise<IFlutterData> {
|
||||||
const storage = await getReleases(platform);
|
const storage = await getReleases(platform);
|
||||||
|
|
||||||
if (version === '') {
|
if (version === '') {
|
||||||
|
@ -73,11 +80,11 @@ async function getReleases(platform: string): Promise<IFlutterStorage> {
|
||||||
async function getLatestVersion(
|
async function getLatestVersion(
|
||||||
storage: IFlutterStorage,
|
storage: IFlutterStorage,
|
||||||
channel: string
|
channel: string
|
||||||
): Promise<{version: string; rawVersion: string; downloadUrl: string}> {
|
): Promise<IFlutterData> {
|
||||||
const channelVersion = storage.releases.find(release => {
|
const channelVersion = storage.releases.find(release => {
|
||||||
return (
|
return (
|
||||||
release.hash === storage.current_release[channel] &&
|
release.hash === storage.current_release[channel] &&
|
||||||
release.channel == channel
|
validateChannel(release.channel, channel)
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -90,25 +97,34 @@ async function getLatestVersion(
|
||||||
|
|
||||||
core.debug(`latest version from channel ${channel} is ${rver}`);
|
core.debug(`latest version from channel ${channel} is ${rver}`);
|
||||||
|
|
||||||
return {
|
const flutterData: IFlutterData = {
|
||||||
|
channel: channelVersion.channel,
|
||||||
version: cver,
|
version: cver,
|
||||||
rawVersion: rver,
|
rawVersion: rver,
|
||||||
downloadUrl: `${storageUrl}/${channelVersion.archive}`
|
downloadUrl: `${storageUrl}/${channelVersion.archive}`
|
||||||
};
|
};
|
||||||
|
|
||||||
|
return flutterData;
|
||||||
|
}
|
||||||
|
|
||||||
|
function validateChannel(releaseChannel: string, channel: string) {
|
||||||
|
return releaseChannel === channel || channel === 'any';
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getWildcardVersion(
|
async function getWildcardVersion(
|
||||||
storage: IFlutterStorage,
|
storage: IFlutterStorage,
|
||||||
channel: string,
|
channel: string,
|
||||||
version: string
|
version: string
|
||||||
): Promise<{version: string; rawVersion: string; downloadUrl: string}> {
|
): Promise<IFlutterData> {
|
||||||
let sver = version.endsWith('.x')
|
let sver = version.endsWith('.x')
|
||||||
? version.slice(0, version.length - 2)
|
? version.slice(0, version.length - 2)
|
||||||
: version;
|
: version;
|
||||||
|
|
||||||
const releases = storage.releases.filter(release => {
|
const releases = storage.releases.filter(release => {
|
||||||
if (release.channel != channel) return false;
|
return (
|
||||||
return prefixCompare(sver, release.version);
|
validateChannel(release.channel, channel) &&
|
||||||
|
prefixCompare(sver, release.version)
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
const versions = releases
|
const versions = releases
|
||||||
|
@ -130,32 +146,40 @@ async function getWildcardVersion(
|
||||||
`latest version of ${version} from channel ${channel} is ${release.version}`
|
`latest version of ${version} from channel ${channel} is ${release.version}`
|
||||||
);
|
);
|
||||||
|
|
||||||
return {
|
const flutterData = {
|
||||||
|
channel: release.channel,
|
||||||
version: cver,
|
version: cver,
|
||||||
rawVersion: release.version,
|
rawVersion: release.version,
|
||||||
downloadUrl: `${storageUrl}/${release.archive}`
|
downloadUrl: `${storageUrl}/${release.archive}`
|
||||||
};
|
};
|
||||||
|
|
||||||
|
return flutterData;
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getVersion(
|
async function getVersion(
|
||||||
storage: IFlutterStorage,
|
storage: IFlutterStorage,
|
||||||
channel: string,
|
channel: string,
|
||||||
version: string
|
version: string
|
||||||
): Promise<{version: string; rawVersion: string; downloadUrl: string}> {
|
): Promise<IFlutterData> {
|
||||||
const release = storage.releases.find(release => {
|
const release = storage.releases.find(release => {
|
||||||
if (release.channel != channel) return false;
|
return (
|
||||||
return compare(version, release.version);
|
validateChannel(release.channel, channel) &&
|
||||||
|
compare(version, release.version)
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!release) {
|
if (!release) {
|
||||||
return getWildcardVersion(storage, channel, version);
|
return getWildcardVersion(storage, channel, version);
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
const flutterData = {
|
||||||
|
channel: release.channel,
|
||||||
version,
|
version,
|
||||||
rawVersion: release.version,
|
rawVersion: release.version,
|
||||||
downloadUrl: `${storageUrl}/${release.archive}`
|
downloadUrl: `${storageUrl}/${release.archive}`
|
||||||
};
|
};
|
||||||
|
|
||||||
|
return flutterData;
|
||||||
}
|
}
|
||||||
|
|
||||||
function compare(version: string, releaseVersion: string): boolean {
|
function compare(version: string, releaseVersion: string): boolean {
|
||||||
|
|
Loading…
Add table
Reference in a new issue