Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F109972840
ExecFutureTestCase.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Thu, Apr 24, 04:53
Size
4 KB
Mime Type
text/x-php
Expires
Sat, Apr 26, 04:53 (2 d)
Engine
blob
Format
Raw Data
Handle
25774060
Attached To
rPHU libphutil
ExecFutureTestCase.php
View Options
<?php
final
class
ExecFutureTestCase
extends
PhutilTestCase
{
public
function
testEmptyWrite
()
{
// NOTE: This is mostly testing that we don't hang while doing an empty
// write.
list
(
$stdout
)
=
id
(
new
ExecFuture
(
'cat'
))->
write
(
''
)->
resolvex
();
$this
->
assertEqual
(
''
,
$stdout
);
}
public
function
testKeepPipe
()
{
// NOTE: This is mosty testing the semantics of $keep_pipe in write().
list
(
$stdout
)
=
id
(
new
ExecFuture
(
'cat'
))
->
write
(
''
,
true
)
->
start
()
->
write
(
'x'
,
true
)
->
write
(
'y'
,
true
)
->
write
(
'z'
,
false
)
->
resolvex
();
$this
->
assertEqual
(
'xyz'
,
$stdout
);
}
public
function
testLargeBuffer
()
{
// NOTE: This is mostly a coverage test to hit branches where we're still
// flushing a buffer.
$data
=
str_repeat
(
'x'
,
1024
*
1024
*
4
);
list
(
$stdout
)
=
id
(
new
ExecFuture
(
'cat'
))->
write
(
$data
)->
resolvex
();
$this
->
assertEqual
(
$data
,
$stdout
);
}
public
function
testBufferLimit
()
{
$data
=
str_repeat
(
'x'
,
1024
*
1024
);
list
(
$stdout
)
=
id
(
new
ExecFuture
(
'cat'
))
->
setStdoutSizeLimit
(
1024
)
->
write
(
$data
)
->
resolvex
();
$this
->
assertEqual
(
substr
(
$data
,
0
,
1024
),
$stdout
);
}
public
function
testResolveTimeoutTestShouldRunLessThan1Sec
()
{
// NOTE: This tests interactions between the resolve() timeout and the
// ExecFuture timeout, which are similar but not identical.
$future
=
id
(
new
ExecFuture
(
'sleep 32000'
))->
start
();
$future
->
setTimeout
(
32000
);
// We expect this to return in 0.01s.
$result
=
$future
->
resolve
(
0.01
);
$this
->
assertEqual
(
$result
,
null
);
// We expect this to now force the time out / kill immediately. If we don't
// do this, we'll hang when exiting until our subprocess exits (32000
// seconds!)
$future
->
setTimeout
(
0.01
);
$future
->
resolve
();
}
public
function
testTimeoutTestShouldRunLessThan1Sec
()
{
// NOTE: This is partly testing that we choose appropriate select wait
// times; this test should run for significantly less than 1 second.
$future
=
new
ExecFuture
(
'sleep 32000'
);
list
(
$err
)
=
$future
->
setTimeout
(
0.01
)->
resolve
();
$this
->
assertTrue
(
$err
>
0
);
$this
->
assertTrue
(
$future
->
getWasKilledByTimeout
());
}
public
function
testMultipleTimeoutsTestShouldRunLessThan1Sec
()
{
$futures
=
array
();
for
(
$ii
=
0
;
$ii
<
4
;
$ii
++)
{
$futures
[]
=
id
(
new
ExecFuture
(
'sleep 32000'
))->
setTimeout
(
0.01
);
}
foreach
(
Futures
(
$futures
)
as
$future
)
{
list
(
$err
)
=
$future
->
resolve
();
$this
->
assertTrue
(
$err
>
0
);
$this
->
assertTrue
(
$future
->
getWasKilledByTimeout
());
}
}
public
function
testNoHangOnExecFutureDestructionWithRunningChild
()
{
$start
=
microtime
(
true
);
$future
=
new
ExecFuture
(
'sleep 30'
);
$future
->
start
();
unset
(
$future
);
$end
=
microtime
(
true
);
// If ExecFuture::__destruct() hangs until the child closes, we won't make
// it here in time.
$this
->
assertTrue
((
$end
-
$start
)
<
5
);
}
public
function
testMultipleResolves
()
{
// It should be safe to call resolve(), resolvex(), resolveKill(), etc.,
// as many times as you want on the same process.
$future
=
new
ExecFuture
(
'echo quack'
);
$future
->
resolve
();
$future
->
resolvex
();
list
(
$err
)
=
$future
->
resolveKill
();
$this
->
assertEqual
(
0
,
$err
);
}
public
function
testReadBuffering
()
{
$str_len_8
=
'abcdefgh'
;
$str_len_4
=
'abcd'
;
// This is a write/read with no read buffer.
$future
=
new
ExecFuture
(
'cat'
);
$future
->
write
(
$str_len_8
);
do
{
$future
->
isReady
();
list
(
$read
)
=
$future
->
read
();
if
(
strlen
(
$read
))
{
break
;
}
}
while
(
true
);
// We expect to get the entire string back in the read.
$this
->
assertEqual
(
$str_len_8
,
$read
);
$future
->
resolve
();
// This is a write/read with a read buffer.
$future
=
new
ExecFuture
(
'cat'
);
$future
->
write
(
$str_len_8
);
// Set the read buffer size.
$future
->
setReadBufferSize
(
4
);
do
{
$future
->
isReady
();
list
(
$read
)
=
$future
->
read
();
if
(
strlen
(
$read
))
{
break
;
}
}
while
(
true
);
// We expect to get the entire string back in the read.
$this
->
assertEqual
(
$str_len_4
,
$read
);
$future
->
resolve
();
}
}
Event Timeline
Log In to Comment