Skip to content

Commit

Permalink
Fix: fix dart type error when attach flex layout underneath of Flutte…
Browse files Browse the repository at this point in the history
…r ListView (#650)

```
══╡ EXCEPTION CAUGHT BY RENDERING LIBRARY ╞═════════════════════════════════════════════════════════
The following _TypeError was thrown during performLayout():
type 'ParentData' is not a subtype of type 'RenderLayoutParentData' in type cast

The relevant error-causing widget was:
  WebF WebF:file:///Users/user/Desktop/Binance/webf/webf/example/lib/main.dart:214:16

When the exception was thrown, this was the stack:
#0      RenderFlexLayout._needToStretchChildCrossSize (package:webf/src/rendering/flex.dart:2243:69)
#1      RenderFlexLayout._getAutoMinSize (package:webf/src/rendering/flex.dart:491:38)
#2      RenderFlexLayout._getMinMainAxisSize (package:webf/src/rendering/flex.dart:369:28)
```
  • Loading branch information
andycall authored Sep 9, 2024
2 parents 2d3b3d2 + a2b58ce commit a3f733b
Show file tree
Hide file tree
Showing 29 changed files with 588 additions and 240 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/integration_test_flutter.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ on: [workflow_dispatch, pull_request]
env:
nodeVersion: "16"
cmakeVersion: "3.22.x"
flutter: "3.22.2"
flutter: "3.24.0"

# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
Expand Down
1 change: 1 addition & 0 deletions bridge/polyfill/src/test/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,7 @@ class JasmineTracker {
resetDocumentElement();
webf.methodChannel.clearMethodCallHandler();
document.___clear_cookies__();
__webf_sync_buffer__();
}
specStarted(result) {
}
Expand Down
6 changes: 6 additions & 0 deletions bridge/test/webf_test_context.cc
Original file line number Diff line number Diff line change
Expand Up @@ -265,6 +265,11 @@ static JSValue parseHTML(JSContext* ctx, JSValueConst this_val, int argc, JSValu
return JS_NULL;
}

static JSValue syncThreadBuffer(JSContext* ctx, JSValueConst this_val, int argc, JSValueConst* argv) {
auto* context = static_cast<ExecutingContext*>(JS_GetContextOpaque(ctx));
context->uiCommandBuffer()->SyncToActive();
}

static JSValue triggerGlobalError(JSContext* ctx, JSValueConst this_val, int argc, JSValueConst* argv) {
auto* context = static_cast<ExecutingContext*>(JS_GetContextOpaque(ctx));

Expand Down Expand Up @@ -357,6 +362,7 @@ WebFTestContext::WebFTestContext(ExecutingContext* context)
{"__webf_environment__", environment, 0},
{"__webf_simulate_pointer__", simulatePointer, 3},
{"__webf_simulate_inputtext__", simulateInputText, 1},
{"__webf_sync_buffer__", syncThreadBuffer, 0},
{"__webf_trigger_global_error__", triggerGlobalError, 0},
{"__webf_parse_html__", parseHTML, 1},
};
Expand Down
1 change: 1 addition & 0 deletions integration_tests/lib/webf_tester.dart
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ class _WebFTesterState extends State<WebFTester> {
disableViewportWidthAssertion: true,
disableViewportHeightAssertion: true,
javaScriptChannel: javaScriptChannel,
runningThread: FlutterUIThread(),
onControllerCreated: onControllerCreated,
onLoad: onLoad,
gestureListener: GestureListener(
Expand Down
55 changes: 55 additions & 0 deletions integration_tests/runtime/global.ts
Original file line number Diff line number Diff line change
Expand Up @@ -315,11 +315,62 @@ async function simulatePointUp(x: number, y: number, pointer: number = 0) {
});
}

function onDoubleImageLoad(img1: HTMLImageElement, img2: HTMLImageElement, onLoadCallback: () => Promise<void>) {
let count = 0;
async function onLoad() {
count++;
if (count >= 2) {
await onLoadCallback();
}
}

img1.addEventListener('load', onLoad);
img2.addEventListener('load', onLoad);
}

function onTripleImageLoad(img1: HTMLImageElement, img2: HTMLImageElement, img3: HTMLImageElement, onLoadCallback: () => Promise<void>) {
let count = 0;
async function onLoad() {
count++;
if (count >= 3) {
await onLoadCallback();
}
}

img1.addEventListener('load', onLoad);
img2.addEventListener('load', onLoad);
img3.addEventListener('load', onLoad);
}

function onFourfoldImageLoad(img1: HTMLImageElement,
img2: HTMLImageElement,
img3: HTMLImageElement,
img4: HTMLImageElement,
onLoadCallback: () => Promise<void>) {
let count = 0;
async function onLoad() {
count++;
if (count >= 4) {
await onLoadCallback();
}
}

img1.addEventListener('load', onLoad);
img2.addEventListener('load', onLoad);
img3.addEventListener('load', onLoad);
img4.addEventListener('load', onLoad);
}

function onImageLoad(img: HTMLImageElement, onLoadCallback: () => Promise<void>) {
img.addEventListener('load', onLoadCallback);
}

function append(parent: HTMLElement, child: Node) {
parent.appendChild(child);
}

async function snapshot(target?: any, filename?: String, postfix?: boolean | string) {
window['__webf_sync_buffer__']();
return new Promise<void>((resolve, reject) => {
requestAnimationFrame(async () => {
try {
Expand Down Expand Up @@ -425,4 +476,8 @@ Object.assign(global, {
cacheSnapshot,
matchCacheSnapshot,
getSnapshot,
onTripleImageLoad,
onImageLoad,
onFourfoldImageLoad,
onDoubleImageLoad
});
2 changes: 1 addition & 1 deletion integration_tests/specs/blob/constructor.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,6 @@ describe('Blob API', () => {
// @ts-ignore
const base64 = await blob.base64();

expect(base64).toEqual('');
expect(base64).toEqual('');
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -44,11 +44,11 @@
<script>
await sleep(0.2);
const main = document.getElementById('main');
expect(main.offsetLeft > 0 && main.offsetLeft < 50).toBe(true);
expect(main.offsetLeft > 0 && main.offsetLeft < 80).toBe(true);
await sleep(1);
expect(main.offsetLeft < 100 && main.offsetLeft > 20).toBe(true);
expect(main.offsetLeft < 100 && main.offsetLeft > 0).toBe(true);
await sleep(0.8);
expect(main.offsetLeft > 100 && main.offsetLeft < 150).toBe(true);
await sleep(0.5);
expect(main.offsetLeft < 50 && main.offsetLeft > 0).toBe(true);
expect(main.offsetLeft < 80 && main.offsetLeft > 0).toBe(true);
</script>
30 changes: 15 additions & 15 deletions integration_tests/specs/css/css-backgrounds/background-position.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ describe('Background-position', () => {
});
position.appendChild(position1);
append(BODY, position);
await snapshot(0.1);
await snapshot(1);
});

it('left', async () => {
Expand All @@ -46,7 +46,7 @@ describe('Background-position', () => {
position.appendChild(position2);

append(BODY, position);
await snapshot(0.5);
await snapshot(1);
});

it('top', async () => {
Expand All @@ -72,7 +72,7 @@ describe('Background-position', () => {
position.appendChild(position3);

append(BODY, position);
await snapshot(0.1);
await snapshot(1);
});

it('right', async () => {
Expand All @@ -98,7 +98,7 @@ describe('Background-position', () => {
position.appendChild(position4);

append(BODY, position);
await snapshot(0.1);
await snapshot(1);
});

it('bottom', async () => {
Expand All @@ -122,7 +122,7 @@ describe('Background-position', () => {
});
position.appendChild(position5);
append(BODY, position);
await snapshot(0.1);
await snapshot(1);
});

it('right center', async () => {
Expand All @@ -145,7 +145,7 @@ describe('Background-position', () => {
});
append(position, div);
append(BODY, position);
await snapshot(0.1);
await snapshot(1);
});

it('should works with length type', async () => {
Expand All @@ -157,7 +157,7 @@ describe('Background-position', () => {
backgroundPosition: '40px 60px',
});
append(BODY, position1);
await snapshot(0.1);
await snapshot(1);
});

it('should works with length type and background-repeat of repeat', async () => {
Expand All @@ -169,7 +169,7 @@ describe('Background-position', () => {
backgroundPosition: '40px 60px',
});
append(BODY, position1);
await snapshot(0.1);
await snapshot(1);
});

it('should works with percentage type', async () => {
Expand All @@ -180,7 +180,7 @@ describe('Background-position', () => {
background: 'url(assets/cat.png) 80% 40% no-repeat yellow',
});
append(BODY, position1);
await snapshot(0.1);
await snapshot(1);
});

it('should works with mixing type 1', async () => {
Expand All @@ -191,7 +191,7 @@ describe('Background-position', () => {
background: 'url(assets/cat.png) 80% 40px no-repeat yellow',
});
append(BODY, position1);
await snapshot(0.1);
await snapshot(1);
});

it('should works with mixing type 2', async () => {
Expand All @@ -202,7 +202,7 @@ describe('Background-position', () => {
background: 'url(assets/cat.png) 40px top no-repeat yellow',
});
append(BODY, position1);
await snapshot(0.1);
await snapshot(1);
});

it('should works with mixing type 3', async () => {
Expand All @@ -213,7 +213,7 @@ describe('Background-position', () => {
background: 'url(assets/cat.png) 30% bottom no-repeat yellow',
});
append(BODY, position1);
await snapshot(0.1);
await snapshot(1);
});

it('should works when background image size is bigger than container size', async () => {
Expand All @@ -224,7 +224,7 @@ describe('Background-position', () => {
background: 'url(assets/cat.png) 20px bottom no-repeat yellow',
});
append(BODY, position1);
await snapshot(0.1);
await snapshot(1);
});

it('should works with background-position-x', async () => {
Expand All @@ -236,7 +236,7 @@ describe('Background-position', () => {
backgroundPositionX: '50px',
});
append(BODY, position1);
await snapshot(0.1);
await snapshot(1);
});

it('should works with background-position-y', async () => {
Expand All @@ -248,7 +248,7 @@ describe('Background-position', () => {
backgroundPositionY: 'bottom',
});
append(BODY, position1);
await snapshot(0.1);
await snapshot(1);
});

it("computed", async () => {
Expand Down
Loading

0 comments on commit a3f733b

Please sign in to comment.