Skip to content

Commit e231112

Browse files
committed
Merge commit '2781888d221ee80ebe3b4f308018e1997a3bb534' into 0.77-merge
2 parents d8af03a + 2781888 commit e231112

File tree

1,563 files changed

+104117
-70363
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

1,563 files changed

+104117
-70363
lines changed

.ado/publish.yml

+3-3
Original file line numberDiff line numberDiff line change
@@ -17,9 +17,9 @@ variables:
1717
- group: InfoSec-SecurityResults
1818
- name: tags
1919
value: production,externalfacing
20-
# CodeQL Still has not fixed their bug running on Apple ARM64 jobs where they inject x64 binaries into arm64 processes and just make it crash :(
21-
# Only workaround for now is to disable CodeQL on Apple jobs.
22-
- name Codeql.Enabled
20+
# CodeQL Still has not fixed their bug running on Apple ARM64 jobs where they inject x64 binaries into arm64 processes and just make it crash :(
21+
# Only workaround for now is to disable CodeQL on Apple jobs.
22+
- name: Codeql.Enabled
2323
value: false
2424
- template: /.ado/variables/vars.yml@self
2525

.eslintrc.js

+1
Original file line numberDiff line numberDiff line change
@@ -30,6 +30,7 @@ module.exports = {
3030
// These rules are not required with hermes-eslint
3131
'ft-flow/define-flow-type': 0,
3232
'ft-flow/use-flow-type': 0,
33+
'lint/sort-imports': 1,
3334
// flow handles this check for us, so it's not required
3435
'no-undef': 0,
3536
},

.flowconfig

+6-1
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,9 @@
2626
; helloworld
2727
<PROJECT_ROOT>/packages/helloworld/ios/Pods/
2828

29+
; Ignore rn-tester Pods
30+
<PROJECT_ROOT>/packages/rn-tester/Pods/
31+
2932
[untyped]
3033
.*/node_modules/@react-native-community/cli/.*/.*
3134

@@ -69,6 +72,8 @@ suppress_type=$FlowFixMeProps
6972
suppress_type=$FlowFixMeState
7073
suppress_type=$FlowFixMeEmpty
7174

75+
ban_spread_key_props=true
76+
7277
[lints]
7378
sketchy-null-number=warn
7479
sketchy-null-mixed=warn
@@ -90,4 +95,4 @@ untyped-import
9095
untyped-type-import
9196

9297
[version]
93-
^0.245.2
98+
^0.254.2

.github/ISSUE_TEMPLATE/bug_report.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
name: 🐛 Bug Report
1+
name: 🐛 React Native - Bug Report
22
description: Report a reproducible bug or regression in React Native.
33
labels: ["Needs: Triage :mag:"]
44
body:
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,76 @@
1+
name: 🔍 Debugger - Bug Report
2+
description: Report a bug with React Native DevTools and the New Debugger
3+
labels: ["Needs: Triage :mag:", "Debugger"]
4+
5+
body:
6+
- type: markdown
7+
attributes:
8+
value: "## Reporting a bug for React Native DevTools"
9+
- type: markdown
10+
attributes:
11+
value: |
12+
Thank you for taking the time to report an issue for React Native DevTools, our new Debugger for React Native.
13+
14+
Before you continue:
15+
* If you're using **Expo** and you're noticing a bug, [report it here](https://github.com/expo/expo/issues).
16+
* If you've found a problem with our **documentation**, [report it here](https://github.com/facebook/react-native-website/issues/).
17+
* If you're having an issue with **Metro** (the bundler), [report it here](https://github.com/facebook/metro/issues/).
18+
* If you're using an external library, report the issue to the **library first**.
19+
* Please [search for similar issues](https://github.com/facebook/react-native/issues) in our issue tracker.
20+
21+
Make sure that your issue is tested against the [**latest stable**](https://github.com/facebook/react-native/releases/) of React Native.
22+
- type: textarea
23+
id: description
24+
attributes:
25+
label: Description
26+
description: A clear and concise description of what the bug is.
27+
validations:
28+
required: true
29+
- type: textarea
30+
id: reproduction
31+
attributes:
32+
label: Steps to reproduce
33+
description: The list of steps that reproduces the issue.
34+
placeholder: |
35+
1. Install the application with `yarn android`
36+
2. Press `j` to open the debugger
37+
3. Do something...
38+
validations:
39+
required: true
40+
- type: input
41+
id: version
42+
attributes:
43+
label: React Native Version
44+
description: The version of react-native that this issue reproduces on. Bear in mind that only issues on [supported versions](https://github.com/reactwg/react-native-releases#which-versions-are-currently-supported) will be looked into.
45+
placeholder: "0.76.0"
46+
validations:
47+
required: true
48+
- type: textarea
49+
id: react-native-info
50+
attributes:
51+
label: Output of `npx react-native info`
52+
description: Run `npx react-native info` in your terminal, copy and paste the results here.
53+
placeholder: |
54+
Paste the output of `npx react-native info` here. The output looks like:
55+
...
56+
System:
57+
OS: macOS 14.1.1
58+
CPU: (10) arm64 Apple M1 Max
59+
Memory: 417.81 MB / 64.00 GB
60+
Shell:
61+
version: "5.9"
62+
path: /bin/zsh
63+
Binaries:
64+
Node: ...
65+
version: 18.14.0
66+
...
67+
render: text
68+
validations:
69+
required: true
70+
- type: textarea
71+
id: extra
72+
attributes:
73+
label: Screenshots and Videos
74+
description: |
75+
Please provide screenshot or a video of your bug if relevant.
76+
Issues with videos and screenshots are more likely to **get prioritized**.

.github/actions/build-apple-slices-hermes/action.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@ inputs:
99
description: The version of Hermes
1010
slice:
1111
required: true
12-
description: The slice of hermes you want to build. It could be iphone, iphonesimulator, macos, catalyst, xros, or xrossimulator
12+
description: The slice of hermes you want to build. It could be iphone, iphonesimulator, macos, catalyst, appletvos, appletvsimulator, xros, or xrossimulator
1313
flavor:
1414
required: true
1515
description: The flavor we want to build. It can be Debug or Release

.github/actions/build-hermes-macos/action.yml

+22-2
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,7 @@ runs:
2222
- name: Restore Cached Artifacts
2323
uses: actions/cache/restore@v4
2424
with:
25-
key: v4-hermes-artifacts-${{ inputs.flavor }}-${{ inputs.hermes-version }}-${{ inputs.react-native-version }}
25+
key: v4-hermes-artifacts-${{ inputs.flavor }}-${{ inputs.hermes-version }}-${{ inputs.react-native-version }}-${{ hashFiles('./packages/react-native/sdks/hermes-engine/utils/build-apple-framework.sh') }}
2626
path: |
2727
/tmp/hermes/osx-bin/${{ inputs.flavor }}
2828
/tmp/hermes/dSYM/${{ inputs.flavor }}
@@ -66,6 +66,18 @@ runs:
6666
with:
6767
path: ./packages/react-native/sdks/hermes/
6868
name: slice-iphonesimulator-${{ inputs.flavor }}
69+
- name: Slice cache appletvos
70+
if: ${{ steps.check_if_apple_artifacts_are_there.outputs.ARTIFACTS_EXIST != 'true' }}
71+
uses: actions/download-artifact@v4
72+
with:
73+
path: ./packages/react-native/sdks/hermes/
74+
name: slice-appletvos-${{ inputs.flavor }}
75+
- name: Slice cache appletvsimulator
76+
if: ${{ steps.check_if_apple_artifacts_are_there.outputs.ARTIFACTS_EXIST != 'true' }}
77+
uses: actions/download-artifact@v4
78+
with:
79+
path: ./packages/react-native/sdks/hermes/
80+
name: slice-appletvsimulator-${{ inputs.flavor }}
6981
- name: Slice cache catalyst
7082
if: ${{ steps.check_if_apple_artifacts_are_there.outputs.ARTIFACTS_EXIST != 'true' }}
7183
uses: actions/download-artifact@v4
@@ -93,6 +105,8 @@ runs:
93105
tar -xzv -f build_catalyst_${{ matrix.flavor }}.tar.gz
94106
tar -xzv -f build_iphoneos_${{ matrix.flavor }}.tar.gz
95107
tar -xzv -f build_iphonesimulator_${{ matrix.flavor }}.tar.gz
108+
tar -xzv -f build_appletvos_${{ matrix.flavor }}.tar.gz
109+
tar -xzv -f build_appletvsimulator_${{ matrix.flavor }}.tar.gz
96110
tar -xzv -f build_macosx_${{ matrix.flavor }}.tar.gz
97111
tar -xzv -f build_xros_${{ matrix.flavor }}.tar.gz
98112
tar -xzv -f build_xrsimulator_${{ matrix.flavor }}.tar.gz
@@ -105,6 +119,8 @@ runs:
105119
mv build_macosx_${{ inputs.flavor }} build_macosx
106120
mv build_iphoneos_${{ inputs.flavor }} build_iphoneos
107121
mv build_iphonesimulator_${{ inputs.flavor }} build_iphonesimulator
122+
mv build_appletvos_${{ inputs.flavor }} build_appletvos
123+
mv build_appletvsimulator_${{ inputs.flavor }} build_appletvsimulator
108124
mv build_catalyst_${{ inputs.flavor }} build_catalyst
109125
mv build_xros_${{ inputs.flavor }} build_xros
110126
mv build_xrsimulator_${{ inputs.flavor }} build_xrsimulator
@@ -163,6 +179,8 @@ runs:
163179
mkdir -p "$WORKING_DIR/catalyst"
164180
mkdir -p "$WORKING_DIR/iphoneos"
165181
mkdir -p "$WORKING_DIR/iphonesimulator"
182+
mkdir -p "$WORKING_DIR/appletvos"
183+
mkdir -p "$WORKING_DIR/appletvsimulator"
166184
mkdir -p "$WORKING_DIR/xros"
167185
mkdir -p "$WORKING_DIR/xrsimulator"
168186
@@ -173,6 +191,8 @@ runs:
173191
cp -r build_catalyst/$DSYM_FILE_PATH "$WORKING_DIR/catalyst/"
174192
cp -r build_iphoneos/$DSYM_FILE_PATH "$WORKING_DIR/iphoneos/"
175193
cp -r build_iphonesimulator/$DSYM_FILE_PATH "$WORKING_DIR/iphonesimulator/"
194+
cp -r build_appletvos/$DSYM_FILE_PATH "$WORKING_DIR/appletvos/"
195+
cp -r build_appletvsimulator/$DSYM_FILE_PATH "$WORKING_DIR/appletvsimulator/"
176196
cp -r build_xros/$DSYM_FILE_PATH "$WORKING_DIR/xros/"
177197
cp -r build_xrsimulator/$DSYM_FILE_PATH "$WORKING_DIR/xrsimulator/"
178198
@@ -200,7 +220,7 @@ runs:
200220
uses: actions/cache/save@v4
201221
if: ${{ github.ref == 'refs/heads/main' || contains(github.ref, '-stable') }} # To avoid that the cache explode.
202222
with:
203-
key: v4-hermes-artifacts-${{ inputs.flavor }}-${{ inputs.hermes-version }}-${{ inputs.react-native-version }}
223+
key: v4-hermes-artifacts-${{ inputs.flavor }}-${{ inputs.hermes-version }}-${{ inputs.react-native-version }}-${{ hashFiles('./packages/react-native/sdks/hermes-engine/utils/build-apple-framework.sh') }}
204224
path: |
205225
/tmp/hermes/osx-bin/${{ inputs.flavor }}
206226
/tmp/hermes/dSYM/${{ inputs.flavor }}

.github/actions/build-hermesc-windows/action.yml

+1-1
Original file line numberDiff line numberDiff line change
@@ -43,7 +43,7 @@ runs:
4343
shell: powershell
4444
run: |
4545
if (-not(Test-Path -Path $Env:HERMES_WS_DIR\win64-bin\hermesc.exe)) {
46-
choco install --no-progress cmake --version 3.14.7
46+
choco install --no-progress cmake --version 3.14.7 --allow-downgrade
4747
if (-not $?) { throw "Failed to install CMake" }
4848
4949
cd $Env:HERMES_WS_DIR\icu

.github/actions/lint/action.yml

+1
Original file line numberDiff line numberDiff line change
@@ -23,6 +23,7 @@ runs:
2323
run: yarn lint-ci
2424
env:
2525
GITHUB_TOKEN: ${{ inputs.github-token }}
26+
GITHUB_PR_NUMBER: ${{ github.event.number }}
2627
- name: Lint code
2728
shell: bash
2829
run: ./scripts/circleci/exec_swallow_error.sh yarn lint --format junit -o ./reports/junit/eslint/results.xml

.github/actions/maestro-android/action.yml

+29-15
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,15 @@ inputs:
1717
required: false
1818
default: 'true'
1919
description: whether this action has to install java 17 or not
20+
flavor:
21+
required: true
22+
description: the flavor we want to run - either debug or release
23+
default: release
24+
working-directory:
25+
required: false
26+
default: "."
27+
description: The directory from which metro should be started
28+
2029
runs:
2130
using: composite
2231
steps:
@@ -25,7 +34,7 @@ runs:
2534
run: export MAESTRO_VERSION=1.36.0; curl -Ls "https://get.maestro.mobile.dev" | bash
2635
- name: Set up JDK 17
2736
if: ${{ inputs.install-java == 'true' }}
28-
uses: actions/setup-java@v2
37+
uses: actions/setup-java@v4
2938
with:
3039
java-version: '17'
3140
distribution: 'zulu'
@@ -38,33 +47,38 @@ runs:
3847
echo 'KERNEL=="kvm", GROUP="kvm", MODE="0666", OPTIONS+="static_node=kvm"' | sudo tee /etc/udev/rules.d/99-kvm4all.rules
3948
sudo udevadm control --reload-rules
4049
sudo udevadm trigger --name-match=kvm
50+
- name: Build Codegen
51+
shell: bash
52+
if: ${{ inputs.flavor == 'debug' }}
53+
run: ./packages/react-native-codegen/scripts/oss/build.sh
4154
- name: Run e2e tests
4255
uses: reactivecircus/android-emulator-runner@v2
4356
with:
4457
api-level: 24
4558
arch: x86
46-
script: |
47-
echo "Install APK from ${{ inputs.app-path }}"
48-
adb install "${{ inputs.app-path }}"
49-
50-
echo "Start recording to /sdcard/screen.mp4"
51-
adb shell screenrecord /sdcard/screen.mp4
52-
53-
echo "Start testing ${{ inputs.maestro-flow }}"
54-
$HOME/.maestro/bin/maestro test ${{ inputs.maestro-flow }} --format junit -e APP_ID=${{ inputs.app-id }} --debug-output /tmp/MaestroLogs
55-
56-
echo "Stop recording. Saving to screen.mp4"
57-
adb pull /sdcard/screen.mp4
59+
ram-size: '4096M'
60+
disk-size: '10G'
61+
disable-animations: false
62+
avd-name: e2e_emulator
63+
script: node .github/workflow-scripts/maestro-android.js ${{ inputs.app-path }} ${{ inputs.app-id }} ${{ inputs.maestro-flow }} ${{ inputs.flavor }} ${{ inputs.working-directory }}
64+
- name: Normalize APP_ID
65+
id: normalize-app-id
66+
shell: bash
67+
if: always()
68+
run: |
69+
NORM_APP_ID=$(echo "${{ inputs.app-id }}" | tr '.' '-')
70+
echo "app-id=$NORM_APP_ID" >> $GITHUB_OUTPUT
5871
- name: Store tests result
5972
uses: actions/upload-artifact@v3
73+
if: always()
6074
with:
61-
name: e2e_android_${{ inputs.app-id }}_report_${{ inputs.jsengine }}
75+
name: e2e_android_${{ steps.normalize-app-id.outputs.app-id }}_report_${{ inputs.jsengine }}_${{ inputs.flavor }}
6276
path: |
6377
report.xml
6478
screen.mp4
6579
- name: Store Logs
6680
if: failure() && steps.run-tests.outcome == 'failure'
6781
uses: actions/[email protected]
6882
with:
69-
name: maestro-logs-android-${{ inputs.app-id }}-${{ inputs.jsengine }}
83+
name: maestro-logs-android-${{ steps.normalize-app-id.outputs.app-id }}-${{ inputs.jsengine }}-${{ inputs.flavor }}
7084
path: /tmp/MaestroLogs

.github/actions/maestro-ios/action.yml

+28-3
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,15 @@ inputs:
1313
maestro-flow:
1414
required: true
1515
description: the folder that contains the maestro tests
16+
flavor:
17+
required: true
18+
description: Whether we are building for Debug or Release
19+
default: Release
20+
working-directory:
21+
required: false
22+
default: "."
23+
description: The directory from which metro should be started
24+
1625
runs:
1726
using: composite
1827
steps:
@@ -29,6 +38,13 @@ runs:
2938
with:
3039
java-version: '17'
3140
distribution: 'zulu'
41+
- name: Start Metro in Debug
42+
shell: bash
43+
if: ${{ inputs.flavor == 'Debug' }}
44+
run: |
45+
cd ${{ inputs.working-directory }}
46+
yarn start &
47+
sleep 5 # to give metro time to load
3248
- name: Run tests
3349
id: run-tests
3450
shell: bash
@@ -53,18 +69,25 @@ runs:
5369
echo "Launch the app"
5470
xcrun simctl launch $UDID ${{ inputs.app-id }}
5571
72+
if [[ ${{ inputs.flavor }} == 'Debug' ]]; then
73+
# To give the app time to warm the metro's cache
74+
sleep 20
75+
fi
76+
5677
echo "Running tests with Maestro"
5778
export MAESTRO_DRIVER_STARTUP_TIMEOUT=1500000 # 25 min. CI is extremely slow
5879
5980
# Add retries for flakyness
60-
MAX_ATTEMPTS=3
81+
MAX_ATTEMPTS=5
6182
CURR_ATTEMPT=0
6283
RESULT=1
6384
6485
while [[ $CURR_ATTEMPT -lt $MAX_ATTEMPTS ]] && [[ $RESULT -ne 0 ]]; do
6586
CURR_ATTEMPT=$((CURR_ATTEMPT+1))
6687
echo "Attempt number $CURR_ATTEMPT"
6788
89+
90+
6891
echo "Start video record using pid: video_record_${{ inputs.jsengine }}_$CURR_ATTEMPT.pid"
6992
xcrun simctl io booted recordVideo video_record_$CURR_ATTEMPT.mov & echo $! > video_record_${{ inputs.jsengine }}_$CURR_ATTEMPT.pid
7093
@@ -82,15 +105,17 @@ runs:
82105
if: always()
83106
uses: actions/[email protected]
84107
with:
85-
name: e2e_ios_${{ inputs.app-id }}_report_${{ inputs.jsengine }}
108+
name: e2e_ios_${{ inputs.app-id }}_report_${{ inputs.jsengine }}_${{ inputs.flavor }}
86109
path: |
87110
video_record_1.mov
88111
video_record_2.mov
89112
video_record_3.mov
113+
video_record_4.mov
114+
video_record_5.mov
90115
report.xml
91116
- name: Store Logs
92117
if: failure() && steps.run-tests.outcome == 'failure'
93118
uses: actions/[email protected]
94119
with:
95-
name: maestro-logs-${{ inputs.app-id }}-${{ inputs.jsengine }}
120+
name: maestro-logs-${{ inputs.app-id }}-${{ inputs.jsengine }}-${{ inputs.flavor }}
96121
path: /tmp/MaestroLogs

.github/actions/prepare-ios-tests/action.yml

-3
Original file line numberDiff line numberDiff line change
@@ -3,9 +3,6 @@ description: Prepare iOS Tests
33
runs:
44
using: composite
55
steps:
6-
- name: brew install xcbeautify
7-
run: brew install xcbeautify
8-
shell: bash
96
- name: Run Ruby Tests
107
shell: bash
118
run: |

0 commit comments

Comments
 (0)