Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
b22388ee
Unverified
Commit
b22388ee
authored
Sep 26, 2022
by
Alex Wallen
Committed by
GitHub
Sep 26, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add a flutter app that can resize itself as integration test app. (#112297)
parent
34407cc0
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
191 additions
and
2 deletions
+191
-2
.ci.yaml
.ci.yaml
+10
-0
TESTOWNERS
TESTOWNERS
+3
-2
integration_ui_test_test_macos.dart
dev/devicelab/bin/tasks/integration_ui_test_test_macos.dart
+12
-0
resize_integration_test.dart
...on_tests/ui/integration_test/resize_integration_test.dart
+57
-0
resize.dart
dev/integration_tests/ui/lib/resize.dart
+76
-0
MainFlutterWindow.swift
...integration_tests/ui/macos/Runner/MainFlutterWindow.swift
+33
-0
No files found.
.ci.yaml
View file @
b22388ee
...
@@ -2642,6 +2642,16 @@ targets:
...
@@ -2642,6 +2642,16 @@ targets:
["devicelab", "hostonly"]
["devicelab", "hostonly"]
task_name: hello_world_macos__compile
task_name: hello_world_macos__compile
-
name
:
Mac integration_ui_test_test_macos
bringup
:
true
recipe
:
devicelab/devicelab_drone
presubmit
:
false
timeout
:
60
properties
:
tags
:
>
["devicelab", "mac"]
task_name
:
integration_ui_test_test_macos
-
name
:
Mac module_custom_host_app_name_test
-
name
:
Mac module_custom_host_app_name_test
recipe
:
devicelab/devicelab_drone
recipe
:
devicelab/devicelab_drone
timeout
:
60
timeout
:
60
...
...
TESTOWNERS
View file @
b22388ee
...
@@ -219,10 +219,10 @@
...
@@ -219,10 +219,10 @@
/dev/devicelab/bin/tasks/flutter_gallery_macos__start_up.dart @a-wallen @flutter/desktop
/dev/devicelab/bin/tasks/flutter_gallery_macos__start_up.dart @a-wallen @flutter/desktop
/dev/devicelab/bin/tasks/flutter_gallery_win_desktop__compile.dart @yaakovschectman @flutter/desktop
/dev/devicelab/bin/tasks/flutter_gallery_win_desktop__compile.dart @yaakovschectman @flutter/desktop
/dev/devicelab/bin/tasks/flutter_gallery_win_desktop__start_up.dart @yaakovschectman @flutter/desktop
/dev/devicelab/bin/tasks/flutter_gallery_win_desktop__start_up.dart @yaakovschectman @flutter/desktop
/dev/devicelab/bin/tasks/flutter_view_macos__start_up.dart @a-wallen @flutter/desktop
/dev/devicelab/bin/tasks/flutter_tool_startup__windows.dart @jensjoha @flutter/tool
/dev/devicelab/bin/tasks/flutter_tool_startup__linux.dart @jensjoha @flutter/tool
/dev/devicelab/bin/tasks/flutter_tool_startup__linux.dart @jensjoha @flutter/tool
/dev/devicelab/bin/tasks/flutter_tool_startup__macos.dart @jensjoha @flutter/tool
/dev/devicelab/bin/tasks/flutter_tool_startup__macos.dart @jensjoha @flutter/tool
/dev/devicelab/bin/tasks/flutter_tool_startup__windows.dart @jensjoha @flutter/tool
/dev/devicelab/bin/tasks/flutter_view_macos__start_up.dart @a-wallen @flutter/desktop
/dev/devicelab/bin/tasks/flutter_view_win_desktop__start_up.dart @yaakovschectman @flutter/desktop
/dev/devicelab/bin/tasks/flutter_view_win_desktop__start_up.dart @yaakovschectman @flutter/desktop
/dev/devicelab/bin/tasks/gradle_desugar_classes_test.dart @zanderso @flutter/tool
/dev/devicelab/bin/tasks/gradle_desugar_classes_test.dart @zanderso @flutter/tool
/dev/devicelab/bin/tasks/gradle_non_android_plugin_test.dart @stuartmorgan @flutter/plugin
/dev/devicelab/bin/tasks/gradle_non_android_plugin_test.dart @stuartmorgan @flutter/plugin
...
@@ -236,6 +236,7 @@
...
@@ -236,6 +236,7 @@
/dev/devicelab/bin/tasks/hello_world_macos__compile.dart @a-wallen @flutter/desktop
/dev/devicelab/bin/tasks/hello_world_macos__compile.dart @a-wallen @flutter/desktop
/dev/devicelab/bin/tasks/hello_world_win_desktop__compile.dart @yaakovschectman @flutter/desktop
/dev/devicelab/bin/tasks/hello_world_win_desktop__compile.dart @yaakovschectman @flutter/desktop
/dev/devicelab/bin/tasks/hot_mode_dev_cycle_win_target__benchmark.dart @cbracken @flutter/desktop
/dev/devicelab/bin/tasks/hot_mode_dev_cycle_win_target__benchmark.dart @cbracken @flutter/desktop
/dev/devicelab/bin/tasks/integration_ui_test_test_macos.dart @a-wallen @flutter/desktop
/dev/devicelab/bin/tasks/module_custom_host_app_name_test.dart @zanderso @flutter/tool
/dev/devicelab/bin/tasks/module_custom_host_app_name_test.dart @zanderso @flutter/tool
/dev/devicelab/bin/tasks/module_host_with_custom_build_test.dart @zanderso @flutter/tool
/dev/devicelab/bin/tasks/module_host_with_custom_build_test.dart @zanderso @flutter/tool
/dev/devicelab/bin/tasks/module_test_ios.dart @jmagman @flutter/tool
/dev/devicelab/bin/tasks/module_test_ios.dart @jmagman @flutter/tool
...
...
dev/devicelab/bin/tasks/integration_ui_test_test_macos.dart
0 → 100644
View file @
b22388ee
// Copyright 2014 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import
'package:flutter_devicelab/framework/devices.dart'
;
import
'package:flutter_devicelab/framework/framework.dart'
;
import
'package:flutter_devicelab/tasks/integration_tests.dart'
;
Future
<
void
>
main
()
async
{
deviceOperatingSystem
=
DeviceOperatingSystem
.
macos
;
await
task
(
createEndToEndIntegrationTest
());
}
dev/integration_tests/ui/integration_test/resize_integration_test.dart
0 → 100644
View file @
b22388ee
// Copyright 2014 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import
'package:flutter/widgets.dart'
as
widgets
show
Container
,
Size
,
runApp
;
import
'package:flutter_test/flutter_test.dart'
;
import
'package:integration_test/integration_test.dart'
;
import
'package:integration_ui/resize.dart'
as
app
;
void
main
(
)
{
IntegrationTestWidgetsFlutterBinding
.
ensureInitialized
();
group
(
'end-to-end test'
,
()
{
testWidgets
(
'Use button to resize window'
,
timeout:
const
Timeout
(
Duration
(
seconds:
5
)),
(
WidgetTester
tester
)
async
{
const
app
.
ResizeApp
resizeApp
=
app
.
ResizeApp
();
widgets
.
runApp
(
resizeApp
);
await
tester
.
pumpAndSettle
();
final
Finder
fab
=
find
.
byKey
(
app
.
ResizeApp
.
extendedFab
);
expect
(
fab
,
findsOneWidget
);
final
Finder
root
=
find
.
byWidget
(
resizeApp
);
final
widgets
.
Size
sizeBefore
=
tester
.
getSize
(
root
);
await
tester
.
tap
(
fab
);
await
tester
.
pumpAndSettle
();
final
widgets
.
Size
sizeAfter
=
tester
.
getSize
(
root
);
expect
(
sizeAfter
.
width
,
equals
(
sizeBefore
.
width
+
app
.
ResizeApp
.
resizeBy
));
expect
(
sizeAfter
.
height
,
equals
(
sizeBefore
.
height
+
app
.
ResizeApp
.
resizeBy
));
final
Finder
widthLabel
=
find
.
byKey
(
app
.
ResizeApp
.
widthLabel
);
expect
(
widthLabel
,
findsOneWidget
);
expect
(
find
.
text
(
'width:
${sizeAfter.width}
'
),
findsOneWidget
);
final
Finder
heightLabel
=
find
.
byKey
(
app
.
ResizeApp
.
heightLabel
);
expect
(
heightLabel
,
findsOneWidget
);
expect
(
find
.
text
(
'height:
${sizeAfter.height}
'
),
findsOneWidget
);
});
});
testWidgets
(
'resize window after calling runApp twice, the second with no content'
,
timeout:
const
Timeout
(
Duration
(
seconds:
5
)),
(
WidgetTester
tester
)
async
{
const
app
.
ResizeApp
root
=
app
.
ResizeApp
();
widgets
.
runApp
(
root
);
widgets
.
runApp
(
widgets
.
Container
());
await
tester
.
pumpAndSettle
();
const
widgets
.
Size
expectedSize
=
widgets
.
Size
(
100
,
100
);
await
app
.
ResizeApp
.
resize
(
expectedSize
);
});
}
dev/integration_tests/ui/lib/resize.dart
0 → 100644
View file @
b22388ee
// Copyright 2014 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import
'package:flutter/material.dart'
;
import
'package:flutter/services.dart'
;
void
main
(
)
async
{
runApp
(
const
ResizeApp
());
}
class
ResizeApp
extends
StatefulWidget
{
const
ResizeApp
({
super
.
key
});
static
const
double
resizeBy
=
10.0
;
static
const
Key
heightLabel
=
Key
(
'height label'
);
static
const
Key
widthLabel
=
Key
(
'width label'
);
static
const
Key
extendedFab
=
Key
(
'extended FAB'
);
static
const
MethodChannel
platform
=
MethodChannel
(
'samples.flutter.dev/resize'
);
static
Future
<
void
>
resize
(
Size
size
)
async
{
await
ResizeApp
.
platform
.
invokeMethod
<
void
>(
'resize'
,
<
String
,
dynamic
>{
'width'
:
size
.
width
,
'height'
:
size
.
height
,
}
);
}
@override
State
<
ResizeApp
>
createState
()
=>
_ResizeAppState
();
}
class
_ResizeAppState
extends
State
<
ResizeApp
>
{
@override
Widget
build
(
BuildContext
context
)
{
return
MaterialApp
(
home:
Builder
(
builder:
(
BuildContext
context
)
{
final
Size
currentSize
=
MediaQuery
.
of
(
context
).
size
;
return
Scaffold
(
floatingActionButton:
FloatingActionButton
.
extended
(
key:
ResizeApp
.
extendedFab
,
label:
const
Text
(
'Resize'
),
onPressed:
()
{
final
Size
nextSize
=
Size
(
currentSize
.
width
+
ResizeApp
.
resizeBy
,
currentSize
.
height
+
ResizeApp
.
resizeBy
,
);
ResizeApp
.
resize
(
nextSize
);
},
),
body:
Center
(
child:
Column
(
mainAxisAlignment:
MainAxisAlignment
.
center
,
children:
<
Widget
>[
Text
(
key:
ResizeApp
.
widthLabel
,
'width:
${currentSize.width}
'
),
Text
(
key:
ResizeApp
.
heightLabel
,
'height:
${currentSize.height}
'
,
),
],
),
),
);
}
),
);
}
}
dev/integration_tests/ui/macos/Runner/MainFlutterWindow.swift
View file @
b22388ee
...
@@ -5,6 +5,12 @@
...
@@ -5,6 +5,12 @@
import
Cocoa
import
Cocoa
import
FlutterMacOS
import
FlutterMacOS
extension
NSWindow
{
var
titlebarHeight
:
CGFloat
{
frame
.
height
-
contentRect
(
forFrameRect
:
frame
)
.
height
}
}
class
MainFlutterWindow
:
NSWindow
{
class
MainFlutterWindow
:
NSWindow
{
override
func
awakeFromNib
()
{
override
func
awakeFromNib
()
{
let
flutterViewController
=
FlutterViewController
.
init
()
let
flutterViewController
=
FlutterViewController
.
init
()
...
@@ -12,8 +18,35 @@ class MainFlutterWindow: NSWindow {
...
@@ -12,8 +18,35 @@ class MainFlutterWindow: NSWindow {
self
.
contentViewController
=
flutterViewController
self
.
contentViewController
=
flutterViewController
self
.
setFrame
(
windowFrame
,
display
:
true
)
self
.
setFrame
(
windowFrame
,
display
:
true
)
RegisterMethodChannel
(
registry
:
flutterViewController
)
RegisterGeneratedPlugins
(
registry
:
flutterViewController
)
RegisterGeneratedPlugins
(
registry
:
flutterViewController
)
super
.
awakeFromNib
()
super
.
awakeFromNib
()
}
}
func
RegisterMethodChannel
(
registry
:
FlutterPluginRegistry
)
{
let
registrar
=
registry
.
registrar
(
forPlugin
:
"resize"
)
let
channel
=
FlutterMethodChannel
(
name
:
"samples.flutter.dev/resize"
,
binaryMessenger
:
registrar
.
messenger
)
channel
.
setMethodCallHandler
({
(
call
,
result
)
in
if
call
.
method
==
"resize"
{
if
let
args
=
call
.
arguments
as?
Dictionary
<
String
,
Any
>
,
let
width
=
args
[
"width"
]
as?
Double
,
var
height
=
args
[
"height"
]
as?
Double
{
height
+=
self
.
titlebarHeight
let
currentFrame
:
NSRect
=
self
.
frame
let
nextFrame
:
NSRect
=
NSMakeRect
(
currentFrame
.
minX
-
(
width
-
currentFrame
.
width
)
/
2
,
currentFrame
.
minY
-
(
height
-
currentFrame
.
height
)
/
2
,
width
,
height
)
self
.
setFrame
(
nextFrame
,
display
:
true
,
animate
:
false
)
result
(
true
)
}
else
{
result
(
FlutterError
.
init
(
code
:
"bad args"
,
message
:
nil
,
details
:
nil
))
}
}
})
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment