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
a1852a19
Unverified
Commit
a1852a19
authored
Sep 27, 2019
by
Jonah Williams
Committed by
GitHub
Sep 27, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Exit resident web runner on initial compilation failure (#41441)
parent
17feb840
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
60 additions
and
6 deletions
+60
-6
resident_web_runner.dart
...utter_tools/lib/src/build_runner/resident_web_runner.dart
+1
-3
web_fs.dart
packages/flutter_tools/lib/src/build_runner/web_fs.dart
+18
-2
web_fs_test.dart
...ges/flutter_tools/test/general.shard/web/web_fs_test.dart
+41
-1
No files found.
packages/flutter_tools/lib/src/build_runner/resident_web_runner.dart
View file @
a1852a19
...
@@ -192,9 +192,7 @@ class ResidentWebRunner extends ResidentRunner {
...
@@ -192,9 +192,7 @@ class ResidentWebRunner extends ResidentRunner {
_connectionResult
=
await
_webFs
.
connect
(
debuggingOptions
);
_connectionResult
=
await
_webFs
.
connect
(
debuggingOptions
);
unawaited
(
_connectionResult
.
debugConnection
.
onDone
.
whenComplete
(
exit
));
unawaited
(
_connectionResult
.
debugConnection
.
onDone
.
whenComplete
(
exit
));
}
}
}
catch
(
err
,
stackTrace
)
{
}
catch
(
err
)
{
printError
(
err
.
toString
());
printError
(
stackTrace
.
toString
());
throwToolExit
(
'Failed to build application for the web.'
);
throwToolExit
(
'Failed to build application for the web.'
);
}
finally
{
}
finally
{
buildStatus
.
stop
();
buildStatus
.
stop
();
...
...
packages/flutter_tools/lib/src/build_runner/web_fs.dart
View file @
a1852a19
...
@@ -135,7 +135,7 @@ class WebFs {
...
@@ -135,7 +135,7 @@ class WebFs {
_client
.
startBuild
();
_client
.
startBuild
();
await
for
(
BuildResults
results
in
_client
.
buildResults
)
{
await
for
(
BuildResults
results
in
_client
.
buildResults
)
{
final
BuildResult
result
=
results
.
results
.
firstWhere
((
BuildResult
result
)
{
final
BuildResult
result
=
results
.
results
.
firstWhere
((
BuildResult
result
)
{
return
result
.
target
==
'web'
;
return
result
.
target
==
kBuildTargetName
;
});
});
if
(
result
.
status
==
BuildStatus
.
failed
)
{
if
(
result
.
status
==
BuildStatus
.
failed
)
{
return
false
;
return
false
;
...
@@ -164,6 +164,7 @@ class WebFs {
...
@@ -164,6 +164,7 @@ class WebFs {
final
bool
hasWebPlugins
=
findPlugins
(
flutterProject
)
final
bool
hasWebPlugins
=
findPlugins
(
flutterProject
)
.
any
((
Plugin
p
)
=>
p
.
platforms
.
containsKey
(
WebPlugin
.
kConfigKey
));
.
any
((
Plugin
p
)
=>
p
.
platforms
.
containsKey
(
WebPlugin
.
kConfigKey
));
// Start the build daemon and run an initial build.
// Start the build daemon and run an initial build.
final
Completer
<
bool
>
inititalBuild
=
Completer
<
bool
>();
final
BuildDaemonClient
client
=
await
buildDaemonCreator
final
BuildDaemonClient
client
=
await
buildDaemonCreator
.
startBuildDaemon
(
fs
.
currentDirectory
.
path
,
.
startBuildDaemon
(
fs
.
currentDirectory
.
path
,
release:
buildInfo
.
isRelease
,
release:
buildInfo
.
isRelease
,
...
@@ -178,6 +179,17 @@ class WebFs {
...
@@ -178,6 +179,17 @@ class WebFs {
return
results
.
results
return
results
.
results
.
firstWhere
((
BuildResult
result
)
=>
result
.
target
==
kBuildTargetName
);
.
firstWhere
((
BuildResult
result
)
=>
result
.
target
==
kBuildTargetName
);
});
});
client
.
buildResults
.
listen
((
BuildResults
buildResults
)
{
final
BuildResult
result
=
buildResults
.
results
.
firstWhere
((
BuildResult
result
)
{
return
result
.
target
==
kBuildTargetName
;
});
if
(
result
.
status
==
BuildStatus
.
failed
)
{
inititalBuild
.
complete
(
false
);
}
if
(
result
.
status
==
BuildStatus
.
succeeded
)
{
inititalBuild
.
complete
(
true
);
}
});
final
int
daemonAssetPort
=
buildDaemonCreator
.
assetServerPort
(
fs
.
currentDirectory
);
final
int
daemonAssetPort
=
buildDaemonCreator
.
assetServerPort
(
fs
.
currentDirectory
);
// Initialize the asset bundle.
// Initialize the asset bundle.
...
@@ -249,13 +261,17 @@ class WebFs {
...
@@ -249,13 +261,17 @@ class WebFs {
cascade
=
cascade
.
add
(
assetServer
.
handle
);
cascade
=
cascade
.
add
(
assetServer
.
handle
);
final
HttpServer
server
=
await
httpMultiServerFactory
(
hostname
??
_kHostName
,
hostPort
);
final
HttpServer
server
=
await
httpMultiServerFactory
(
hostname
??
_kHostName
,
hostPort
);
shelf_io
.
serveRequests
(
server
,
cascade
.
handler
);
shelf_io
.
serveRequests
(
server
,
cascade
.
handler
);
return
WebFs
(
final
WebFs
webFS
=
WebFs
(
client
,
client
,
server
,
server
,
dwds
,
dwds
,
'http://
$_kHostName
:
$hostPort
/'
,
'http://
$_kHostName
:
$hostPort
/'
,
assetServer
,
assetServer
,
);
);
if
(!
await
inititalBuild
.
future
)
{
throw
Exception
(
'Failed to compile for the web.'
);
}
return
webFS
;
}
}
}
}
...
...
packages/flutter_tools/test/general.shard/web/web_fs_test.dart
View file @
a1852a19
...
@@ -4,6 +4,7 @@
...
@@ -4,6 +4,7 @@
import
'package:build_daemon/client.dart'
;
import
'package:build_daemon/client.dart'
;
import
'package:build_daemon/data/build_status.dart'
;
import
'package:build_daemon/data/build_status.dart'
;
import
'package:built_collection/built_collection.dart'
;
import
'package:dwds/dwds.dart'
;
import
'package:dwds/dwds.dart'
;
import
'package:flutter_tools/src/base/file_system.dart'
;
import
'package:flutter_tools/src/base/file_system.dart'
;
import
'package:flutter_tools/src/base/os.dart'
;
import
'package:flutter_tools/src/base/os.dart'
;
...
@@ -49,7 +50,18 @@ void main() {
...
@@ -49,7 +50,18 @@ void main() {
return
1234
;
return
1234
;
});
});
when
(
mockBuildDaemonClient
.
buildResults
).
thenAnswer
((
Invocation
_
)
{
when
(
mockBuildDaemonClient
.
buildResults
).
thenAnswer
((
Invocation
_
)
{
return
const
Stream
<
BuildResults
>.
empty
();
return
Stream
<
BuildResults
>.
fromFuture
(
Future
<
BuildResults
>.
value
(
BuildResults
((
BuildResultsBuilder
builder
)
{
builder
.
results
=
ListBuilder
<
BuildResult
>(
<
BuildResult
>[
DefaultBuildResult
((
DefaultBuildResultBuilder
builder
)
{
builder
.
target
=
'web'
;
builder
.
status
=
BuildStatus
.
succeeded
;
})
]
);
})
));
});
});
when
(
mockBuildDaemonCreator
.
assetServerPort
(
any
)).
thenReturn
(
4321
);
when
(
mockBuildDaemonCreator
.
assetServerPort
(
any
)).
thenReturn
(
4321
);
testbed
=
Testbed
(
testbed
=
Testbed
(
...
@@ -141,6 +153,34 @@ void main() {
...
@@ -141,6 +153,34 @@ void main() {
expect
(
lastPort
,
1234
);
expect
(
lastPort
,
1234
);
expect
(
lastAddress
,
contains
(
'foo'
));
expect
(
lastAddress
,
contains
(
'foo'
));
}));
}));
test
(
'Throws exception if build fails'
,
()
=>
testbed
.
run
(()
async
{
when
(
mockBuildDaemonClient
.
buildResults
).
thenAnswer
((
Invocation
_
)
{
return
Stream
<
BuildResults
>.
fromFuture
(
Future
<
BuildResults
>.
value
(
BuildResults
((
BuildResultsBuilder
builder
)
{
builder
.
results
=
ListBuilder
<
BuildResult
>(
<
BuildResult
>[
DefaultBuildResult
((
DefaultBuildResultBuilder
builder
)
{
builder
.
target
=
'web'
;
builder
.
status
=
BuildStatus
.
failed
;
})
]
);
})
));
});
final
FlutterProject
flutterProject
=
FlutterProject
.
current
();
expect
(
WebFs
.
start
(
skipDwds:
false
,
target:
fs
.
path
.
join
(
'lib'
,
'main.dart'
),
buildInfo:
BuildInfo
.
debug
,
flutterProject:
flutterProject
,
initializePlatform:
false
,
hostname:
'foo'
,
port:
'1234'
,
),
throwsA
(
isInstanceOf
<
Exception
>()));
}));
}
}
class
MockBuildDaemonCreator
extends
Mock
implements
BuildDaemonCreator
{}
class
MockBuildDaemonCreator
extends
Mock
implements
BuildDaemonCreator
{}
...
...
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