Skip to content

Commit 23ee720

Browse files
authored
ci: nightly builds against react-native-macos/-windows canaries (#328)
1 parent b38f898 commit 23ee720

File tree

7 files changed

+78
-184
lines changed

7 files changed

+78
-184
lines changed

.github/workflows/build.yml

+15-4
Original file line numberDiff line numberDiff line change
@@ -304,7 +304,7 @@ jobs:
304304
macos:
305305
name: "macOS"
306306
runs-on: macos-latest
307-
if: ${{ github.event_name != 'schedule' && !contains(github.event.head_commit.message, '[skip ci]') }}
307+
if: ${{ !contains(github.event.head_commit.message, '[skip ci]') }}
308308
steps:
309309
- name: Set up Node.js
310310
uses: actions/[email protected]
@@ -317,6 +317,11 @@ jobs:
317317
with:
318318
path: example/.yarn-offline-mirror
319319
key: ${{ hashFiles('example/yarn.lock') }}
320+
- name: Set up react-native@canary
321+
if: ${{ github.event_name == 'schedule' }}
322+
run: |
323+
yarn set-react-version canary-macos
324+
shell: bash
320325
- name: Install
321326
run: |
322327
yarn ci
@@ -386,10 +391,10 @@ jobs:
386391
windows:
387392
name: "Windows"
388393
runs-on: windows-latest
389-
if: ${{ github.event_name != 'schedule' && !contains(github.event.head_commit.message, '[skip ci]') }}
394+
if: ${{ !contains(github.event.head_commit.message, '[skip ci]') }}
390395
strategy:
391396
matrix:
392-
platform: [ARM, x64]
397+
platform: [ARM64, x64]
393398
configuration: [Debug, Release]
394399
steps:
395400
- name: Set up MSBuild
@@ -407,6 +412,11 @@ jobs:
407412
with:
408413
path: example/.yarn-offline-mirror
409414
key: ${{ hashFiles('example/yarn.lock') }}
415+
- name: Set up react-native@canary
416+
if: ${{ github.event_name == 'schedule' }}
417+
run: |
418+
yarn set-react-version canary-windows
419+
shell: bash
410420
- name: Install
411421
run: |
412422
yarn ci
@@ -425,9 +435,10 @@ jobs:
425435
MSBuild Example.sln -t:Rebuild -p:Configuration=${{ matrix.configuration }} -p:Platform=${{ matrix.platform }}
426436
working-directory: example/windows
427437
- name: Test
438+
if: ${{ matrix.platform == 'x64' }}
428439
run: |
429440
MSBuild ReactTestAppTests.vcxproj -t:Build -p:Configuration=${{ matrix.configuration }} -p:Platform=${{ matrix.platform }}
430-
if ("${{ matrix.platform }}" -eq "x64") { VSTest.Console.exe ${{ matrix.platform }}\${{ matrix.configuration }}\ReactTestAppTests.dll }
441+
VSTest.Console.exe ${{ matrix.platform }}\${{ matrix.configuration }}\ReactTestAppTests.dll
431442
working-directory: example/windows/ReactTestAppTests
432443
windows-template:
433444
name: "Windows [template]"

example/windows/ReactTestAppTests/ReactTestAppTests.vcxproj

+42-172
Large diffs are not rendered by default.

ios/ReactTestApp/React+Compatibility.m

+2-2
Original file line numberDiff line numberDiff line change
@@ -38,13 +38,13 @@ IMP RTASwizzleSelector(Class class, SEL originalSelector, SEL swizzledSelector)
3838

3939
// `RCTReloadCommand.h` is excluded from `react-native-macos`
4040
// See https://github.com/microsoft/react-native-macos/blob/v0.61.39/React-Core.podspec#L66
41-
#if REACT_NATIVE_VERSION >= 6200
41+
#if REACT_NATIVE_VERSION == 0 || REACT_NATIVE_VERSION >= 6200
4242
#import <React/RCTReloadCommand.h>
4343
#endif
4444

4545
void RTATriggerReloadCommand(RCTBridge *bridge, NSString *reason)
4646
{
47-
#if REACT_NATIVE_VERSION < 6200
47+
#if REACT_NATIVE_VERSION > 0 && REACT_NATIVE_VERSION < 6200
4848
[bridge reload];
4949
#else
5050
RCTTriggerReloadCommandListeners(reason);

scripts/set-react-version.js

+12
Original file line numberDiff line numberDiff line change
@@ -38,6 +38,18 @@ const profiles = {
3838
"react-native-macos": undefined,
3939
"react-native-windows": "^0.64.11",
4040
},
41+
"canary-macos": {
42+
react: "16.13.1",
43+
"react-native": "^0.63.4",
44+
"react-native-macos": "canary",
45+
"react-native-windows": undefined,
46+
},
47+
"canary-windows": {
48+
react: "17.0.2",
49+
"react-native": "^0.64.2",
50+
"react-native-macos": undefined,
51+
"react-native-windows": "canary",
52+
},
4153
master: {
4254
react: "17.0.2",
4355
"react-native": "facebook/react-native#master",

test/windows-test-app/getVersionNumber.test.js

+2
Original file line numberDiff line numberDiff line change
@@ -44,5 +44,7 @@ describe("getVersionNumber", () => {
4444
expect(getVersionNumber("1.1.0.1")).toBe(1010001);
4545
expect(getVersionNumber("1.1.1.0")).toBe(1010100);
4646
expect(getVersionNumber("1.1.1.1")).toBe(1010101);
47+
48+
expect(getVersionNumber("1.0.0-rc.1")).toBe(10000);
4749
});
4850
});

windows/ReactTestApp/ReactTestApp.vcxproj

+4-5
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@
1414
<AppContainerApplication>true</AppContainerApplication>
1515
<ApplicationType>Windows Store</ApplicationType>
1616
<ApplicationTypeRevision>10.0</ApplicationTypeRevision>
17-
<WindowsTargetPlatformVersion Condition=" '$(WindowsTargetPlatformVersion)' == '' ">10.0.18362.0</WindowsTargetPlatformVersion>
17+
<WindowsTargetPlatformVersion Condition=" '$(WindowsTargetPlatformVersion)' == '' ">10.0.19041.0</WindowsTargetPlatformVersion>
1818
<WindowsTargetPlatformMinVersion>10.0.17763.0</WindowsTargetPlatformMinVersion>
1919
<PackageCertificateKeyFile>ReactTestApp_TemporaryKey.pfx</PackageCertificateKeyFile>
2020
<PackageCertificateThumbprint>4AC7A41A12F06BCFEDBADCE05ECFFDF546109B66</PackageCertificateThumbprint>
@@ -126,21 +126,20 @@
126126
<AdditionalOptions>%(AdditionalOptions) /bigobj</AdditionalOptions>
127127
<!--Temporarily disable cppwinrt heap enforcement to work around xaml compiler generated std::shared_ptr use -->
128128
<AdditionalOptions Condition="'$(CppWinRTHeapEnforcement)'==''">/DWINRT_NO_MAKE_DETECTION %(AdditionalOptions)</AdditionalOptions>
129-
<DisableSpecificWarnings>
130-
</DisableSpecificWarnings>
129+
<DisableSpecificWarnings></DisableSpecificWarnings>
131130
<PreprocessorDefinitions>WIN32_LEAN_AND_MEAN;WINRT_LEAN_AND_MEAN;REACT_NATIVE_VERSION=10000000;%(PreprocessorDefinitions)</PreprocessorDefinitions>
132131
</ClCompile>
133132
</ItemDefinitionGroup>
134133
<ItemDefinitionGroup Condition="'$(Configuration)'=='Debug'">
135134
<ClCompile>
136135
<PreprocessorDefinitions>_DEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions>
137-
<TreatWarningAsError>true</TreatWarningAsError>
136+
<TreatWarningAsError>false</TreatWarningAsError>
138137
</ClCompile>
139138
</ItemDefinitionGroup>
140139
<ItemDefinitionGroup Condition="'$(Configuration)'=='Release'">
141140
<ClCompile>
142141
<PreprocessorDefinitions>NDEBUG;%(PreprocessorDefinitions)</PreprocessorDefinitions>
143-
<TreatWarningAsError>true</TreatWarningAsError>
142+
<TreatWarningAsError>false</TreatWarningAsError>
144143
</ClCompile>
145144
</ItemDefinitionGroup>
146145
<ItemGroup>

windows/test-app.js

+1-1
Original file line numberDiff line numberDiff line change
@@ -261,7 +261,7 @@ function getPackageVersion(packagePath) {
261261
* @returns {number}
262262
*/
263263
function getVersionNumber(version) {
264-
const components = version.split(".");
264+
const components = version.split("-")[0].split(".");
265265
const lastIndex = components.length - 1;
266266
return components.reduce(
267267
/** @type {(sum: number, value: string, index: number) => number} */

0 commit comments

Comments
 (0)