2021-05-07 13:21:23 -04:00
|
|
|
"""
|
|
|
|
Ported to Python 3.
|
|
|
|
"""
|
|
|
|
from __future__ import absolute_import
|
|
|
|
from __future__ import division
|
|
|
|
from __future__ import print_function
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
|
|
|
from future.utils import PY2
|
|
|
|
if PY2:
|
|
|
|
from future.builtins import filter, map, zip, ascii, chr, hex, input, next, oct, open, pow, round, super, bytes, dict, list, object, range, str, max, min # noqa: F401
|
|
|
|
|
2017-02-14 16:36:57 -07:00
|
|
|
import sys
|
2017-07-26 11:29:47 -04:00
|
|
|
from os.path import join
|
2017-02-14 16:36:57 -07:00
|
|
|
|
|
|
|
from twisted.internet.error import ProcessTerminated
|
|
|
|
|
2021-05-07 10:06:12 -04:00
|
|
|
from . import util
|
2017-02-14 16:36:57 -07:00
|
|
|
|
2019-02-05 11:03:35 -05:00
|
|
|
import pytest_twisted
|
2017-02-14 16:36:57 -07:00
|
|
|
|
|
|
|
|
2019-02-05 11:03:35 -05:00
|
|
|
@pytest_twisted.inlineCallbacks
|
2017-02-14 16:36:57 -07:00
|
|
|
def test_upload_immutable(reactor, temp_dir, introducer_furl, flog_gatherer, storage_nodes, request):
|
|
|
|
|
2019-08-08 21:39:53 -06:00
|
|
|
edna = yield util._create_node(
|
2017-02-14 16:36:57 -07:00
|
|
|
reactor, request, temp_dir, introducer_furl, flog_gatherer, "edna",
|
|
|
|
web_port="tcp:9983:interface=localhost",
|
|
|
|
storage=False,
|
|
|
|
needed=3,
|
2017-07-26 11:30:02 -04:00
|
|
|
happy=7,
|
2017-02-14 16:36:57 -07:00
|
|
|
total=10,
|
|
|
|
)
|
2019-08-08 21:39:53 -06:00
|
|
|
util.await_client_ready(edna)
|
2017-02-14 16:36:57 -07:00
|
|
|
|
|
|
|
node_dir = join(temp_dir, 'edna')
|
|
|
|
|
|
|
|
# upload a file, which should fail because we have don't have 7
|
|
|
|
# storage servers (but happiness is set to 7)
|
|
|
|
proto = util._CollectOutputProtocol()
|
2017-07-26 11:29:47 -04:00
|
|
|
reactor.spawnProcess(
|
2017-02-14 16:36:57 -07:00
|
|
|
proto,
|
|
|
|
sys.executable,
|
|
|
|
[
|
2021-04-16 11:58:37 -04:00
|
|
|
sys.executable, '-b', '-m', 'allmydata.scripts.runner',
|
2017-02-14 16:36:57 -07:00
|
|
|
'-d', node_dir,
|
|
|
|
'put', __file__,
|
|
|
|
]
|
|
|
|
)
|
|
|
|
try:
|
|
|
|
yield proto.done
|
|
|
|
assert False, "should raise exception"
|
|
|
|
except Exception as e:
|
|
|
|
assert isinstance(e, ProcessTerminated)
|
|
|
|
|
|
|
|
output = proto.output.getvalue()
|
2021-05-07 10:48:50 -04:00
|
|
|
assert b"shares could be placed on only" in output
|