def test_deposit_index(db, es): """Test update embargoed records.""" deposit_index_name = 'deposits-records-record-v1.0.0' rec1 = Record.create({ 'title': 'One', '_deposit': { 'status': 'published', 'pid': { 'type': 'recid', 'value': '1' } } }) PersistentIdentifier.create(pid_type='recid', pid_value='1', status=PIDStatus.REGISTERED, object_uuid=rec1.id, object_type='rec') Deposit.create({ '_deposit': { 'status': 'published', 'pid': { 'type': 'recid', 'value': '1' } } }) db.session.commit() current_search.flush_and_refresh(deposit_index_name) res = current_search.client.search(index=deposit_index_name) # Make sure the 'title' was indexed from record assert res['hits']['hits'][0]['_source']['title'] == 'One'
def test_deposit_index(db, es): """Test update embargoed records.""" deposit_index_name = 'deposits-records-record-v1.0.0' rec1 = Record.create({ 'title': 'One', '_deposit': { 'status': 'published', 'pid': { 'type': 'recid', 'value': '1' } } }) PersistentIdentifier.create(pid_type='recid', pid_value='1', status=PIDStatus.REGISTERED, object_uuid=rec1.id, object_type='rec') Deposit.create({ '_deposit': { 'status': 'published', 'pid': { 'type': 'recid', 'value': '1' } } }) db.session.commit() current_search.flush_and_refresh(deposit_index_name) res = current_search.client.search(index=deposit_index_name) # Make sure the 'title' was indexed from record assert res['hits']['hits'][0]['_source']['title'] == 'One'
def test_created_by_population(app, db, users): """Test created_by gets populated correctly.""" record = {'title': 'fuu'} deposit = Deposit.create(record) assert 'created_by' not in deposit['_deposit'] with app.test_request_context(): login_user(users[0]) deposit = Deposit.create(record) assert deposit['_deposit']['created_by'] == users[0].id
def test_created_by_population(api, users, location): """Test created_by gets populated correctly.""" record = {'title': 'fuu'} deposit = Deposit.create(record) assert 'created_by' not in deposit['_deposit'] with api.test_request_context(): datastore = api.extensions['security'].datastore login_user(datastore.find_user(email=users[0]['email'])) deposit = Deposit.create(record) assert deposit['_deposit']['created_by'] == users[0]['id']
def test_created_by_population(app, db, users): """Test created_by gets populated correctly.""" record = { 'title': 'fuu' } deposit = Deposit.create(record) assert 'created_by' not in deposit['_deposit'] with app.test_request_context(): login_user(users[0]) deposit = Deposit.create(record) assert deposit['_deposit']['created_by'] == users[0].id
def test_schemas(app, db, fake_schemas): """Test schema URL transformations.""" deposit = Deposit.create({}) assert "http://localhost/schemas/deposits/deposit-v1.0.0.json" == deposit["$schema"] assert "http://localhost/schemas/deposit-v1.0.0.json" == deposit.record_schema assert "http://localhost/schemas/deposits/test-v1.0.0.json" == deposit.build_deposit_schema( {"$schema": "http://localhost/schemas/test-v1.0.0.json"} ) with pytest.raises(RefResolutionError): Deposit.create({"$schema": "http://localhost/schemas/deposits/invalid.json"})
def test_created_by_population(api, users): """Test created_by gets populated correctly.""" record = { 'title': 'fuu' } deposit = Deposit.create(record) assert 'created_by' not in deposit['_deposit'] with api.test_request_context(): datastore = api.extensions['security'].datastore login_user(datastore.find_user(email=users[0]['email'])) deposit = Deposit.create(record) assert deposit['_deposit']['created_by'] == users[0]['id']
def records(): """Load records.""" from flask_login import login_user, logout_user from invenio_accounts.models import User from invenio_deposit.api import Deposit user = User.query.one() with current_app.test_request_context(): login_user(user) with db.session.begin_nested(): Deposit.create({'title': 'Test'}) logout_user() db.session.commit()
def test_publish_revision_changed_mergeable(app, db, location, fake_schemas): """Try to Publish and someone change the deposit in the while.""" # create a deposit deposit = Deposit.create({"metadata": {"title": "title-1"}}) deposit.commit() db.session.commit() # publish deposit.publish() db.session.commit() # edit deposit = deposit.edit() db.session.commit() # simulate a externally modification rid, record = deposit.fetch_published() rev_id = record.revision_id # try to change metadata record.update({"metadata": {"title": "title-1", "poster": "myposter"}}) record.commit() db.session.commit() assert rev_id != record.revision_id # edit again and check the merging deposit.update({"metadata": {"title": "title-1", "description": "mydesc"}}) deposit.commit() deposit.publish() db.session.commit() # check if is properly merged did, deposit = deposit.fetch_published() assert deposit["metadata"]["title"] == "title-1" assert deposit["metadata"]["poster"] == "myposter" assert deposit["metadata"]["description"] == "mydesc" assert deposit["$schema"] == "http://localhost/schemas/deposit-v1.0.0.json"
def records(): """Load records.""" import pkg_resources import uuid from flask_login import login_user, logout_user from dojson.contrib.marc21 import marc21 from dojson.contrib.marc21.utils import create_record, split_blob from invenio_accounts.models import User from invenio_deposit.api import Deposit users = User.query.all() # pkg resources the demodata data_path = pkg_resources.resource_filename( 'invenio_records', 'data/marc21/bibliographic.xml' ) with open(data_path) as source: with current_app.test_request_context(): indexer = RecordIndexer() with db.session.begin_nested(): for index, data in enumerate(split_blob(source.read()), start=1): login_user(users[index % len(users)]) # do translate record = marc21.do(create_record(data)) # create record indexer.index(Deposit.create(record)) logout_user() db.session.commit()
def test_publish_revision_changed_mergeable(app, db, location, fake_schemas): """Try to Publish and someone change the deposit in the while.""" # create a deposit deposit = Deposit.create({"metadata": {"title": "title-1"}}) deposit.commit() db.session.commit() # publish deposit.publish() db.session.commit() # edit deposit = deposit.edit() db.session.commit() # simulate a externally modification rid, record = deposit.fetch_published() rev_id = record.revision_id # try to change metadata record.update({ 'metadata': {"title": "title-1", 'poster': 'myposter'}, }) record.commit() db.session.commit() assert rev_id != record.revision_id # edit again and check the merging deposit.update({"metadata": {"title": "title-1", "description": "mydesc"}}) deposit.commit() deposit.publish() db.session.commit() # check if is properly merged did, deposit = deposit.fetch_published() assert deposit['metadata']['title'] == 'title-1' assert deposit['metadata']['poster'] == 'myposter' assert deposit['metadata']['description'] == 'mydesc' assert deposit['$schema'] == 'http://localhost/schemas/deposit-v1.0.0.json'
def records(): """Load records.""" import pkg_resources from dojson.contrib.marc21 import marc21 from dojson.contrib.marc21.utils import create_record, split_blob from flask_login import login_user, logout_user from invenio_accounts.models import User from invenio_deposit.api import Deposit users = User.query.all() # pkg resources the demodata data_path = pkg_resources.resource_filename( 'invenio_records', 'data/marc21/bibliographic.xml') with open(data_path) as source: with current_app.test_request_context(): indexer = RecordIndexer() with db.session.begin_nested(): for index, data in enumerate(split_blob(source.read()), start=1): login_user(users[index % len(users)]) # do translate record = marc21.do(create_record(data)) # create record indexer.index(Deposit.create(record)) logout_user() db.session.commit()
def test_publish_revision_changed_not_mergeable(app, location, fake_schemas): """Try to Publish and someone change the deposit in the while.""" # create a deposit deposit = Deposit.create({"metadata": { "title": "title-1", }}) deposit.commit() db.session.commit() # publish deposit.publish() db.session.commit() # edit deposit = deposit.edit() db.session.commit() # simulate a externally modification rid, record = deposit.fetch_published() rev_id = record.revision_id record.update({'metadata': { "title": "title-2.1", }}) record.commit() db.session.commit() assert rev_id != record.revision_id # edit again and check the merging deposit.update({"metadata": { "title": "title-2.2", }}) deposit.commit() with pytest.raises(MergeConflict): deposit.publish()
def test_publish_revision_changed_not_mergeable(app, location, fake_schemas): """Try to Publish and someone change the deposit in the while.""" # create a deposit deposit = Deposit.create({"metadata": { "title": "title-1", }}) deposit.commit() db.session.commit() # publish deposit.publish() db.session.commit() # edit deposit = deposit.edit() db.session.commit() # simulate a externally modification rid, record = deposit.fetch_published() rev_id = record.revision_id record.update({'metadata': { "title": "title-2.1", }}) record.commit() db.session.commit() assert rev_id != record.revision_id # edit again and check the merging deposit.update({"metadata": { "title": "title-2.2", }}) deposit.commit() with pytest.raises(MergeConflict): deposit.publish()
def test_schemas(app, fake_schemas): """Test schema URL transformations.""" deposit = Deposit.create({}) assert 'http://localhost/schemas/deposits/deposit-v1.0.0.json' == \ deposit['$schema'] assert 'http://localhost/schemas/deposit-v1.0.0.json' == \ deposit.record_schema assert 'http://localhost/schemas/deposits/test-v1.0.0.json' == \ deposit.build_deposit_schema({ '$schema': 'http://localhost/schemas/test-v1.0.0.json', }) with pytest.raises(RefResolutionError): Deposit.create({ '$schema': 'http://localhost/schemas/deposits/invalid.json', })
def test_schemas(app, db, fake_schemas): """Test schema URL transformations.""" deposit = Deposit.create({}) assert 'http://localhost/schemas/deposits/deposit-v1.0.0.json' == \ deposit['$schema'] assert 'http://localhost/schemas/deposit-v1.0.0.json' == \ deposit.record_schema assert 'http://localhost/schemas/deposits/test-v1.0.0.json' == \ deposit.build_deposit_schema({ '$schema': 'http://localhost/schemas/test-v1.0.0.json', }) with pytest.raises(RefResolutionError): Deposit.create({ '$schema': 'http://localhost/schemas/deposits/invalid.json', })
def depid(app, users, db): """New deposit with files.""" record = {'title': {'title': 'fuu'}} with app.test_request_context(): login_user(User.query.get(users[0])) deposit = Deposit.create(record) deposit.commit() db.session.commit() return deposit['_deposit']['id']
def test_simple_flow(app, fake_schemas, location): """Test simple flow of deposit states through its lifetime.""" deposit = Deposit.create({}) assert deposit['_deposit']['id'] assert 'draft' == deposit.status assert 0 == deposit.revision_id deposit.publish() assert 'published' == deposit.status assert 1 == deposit.revision_id with pytest.raises(PIDInvalidAction): deposit.delete() with pytest.raises(PIDInvalidAction): deposit.clear() with pytest.raises(PIDInvalidAction): deposit.update(title='Revision 2') assert 'published' == deposit.status deposit = deposit.edit() assert 'draft' == deposit.status assert 2 == deposit.revision_id assert 0 == deposit['_deposit']['pid']['revision_id'] with pytest.raises(PIDInvalidAction): deposit.edit() assert 'draft' == deposit.status deposit['title'] = 'Revision 1' deposit.publish() assert 'published' == deposit.status assert 3 == deposit.revision_id assert 0 == deposit['_deposit']['pid']['revision_id'] deposit = deposit.edit() assert 'draft' == deposit.status assert 4 == deposit.revision_id assert 1 == deposit['_deposit']['pid']['revision_id'] deposit['title'] = 'Revision 2' deposit.commit() assert 5 == deposit.revision_id (_, record) = deposit.fetch_published() record_schema_before = record['$schema'] record_json = deepcopy(record.model.json) deposit = deposit.discard() assert 'published' == deposit.status assert 'Revision 1' == deposit['title'] assert 6 == deposit.revision_id (_, record) = deposit.fetch_published() record_schema_after = record['$schema'] assert record_schema_before == record_schema_after assert record_json == record.model.json
def test_simple_flow(app, db, fake_schemas, location): """Test simple flow of deposit states through its lifetime.""" deposit = Deposit.create({}) assert deposit["_deposit"]["id"] assert "draft" == deposit.status assert 0 == deposit.revision_id deposit.publish() assert "published" == deposit.status assert 1 == deposit.revision_id with pytest.raises(PIDInvalidAction): deposit.delete() with pytest.raises(PIDInvalidAction): deposit.clear() with pytest.raises(PIDInvalidAction): deposit.update(title="Revision 2") assert "published" == deposit.status deposit = deposit.edit() assert "draft" == deposit.status assert 2 == deposit.revision_id assert 0 == deposit["_deposit"]["pid"]["revision_id"] with pytest.raises(PIDInvalidAction): deposit.edit() assert "draft" == deposit.status deposit["title"] = "Revision 1" deposit.publish() assert "published" == deposit.status assert 3 == deposit.revision_id assert 0 == deposit["_deposit"]["pid"]["revision_id"] deposit = deposit.edit() assert "draft" == deposit.status assert 4 == deposit.revision_id assert 1 == deposit["_deposit"]["pid"]["revision_id"] deposit["title"] = "Revision 2" deposit.commit() assert 5 == deposit.revision_id (_, record) = deposit.fetch_published() record_schema_before = record["$schema"] record_json = deepcopy(record.model.json) deposit = deposit.discard() assert "published" == deposit.status assert "Revision 1" == deposit["title"] assert 6 == deposit.revision_id (_, record) = deposit.fetch_published() record_schema_after = record["$schema"] assert record_schema_before == record_schema_after assert record_json == record.model.json
def test_simple_flow(app, fake_schemas, location): """Test simple flow of deposit states through its lifetime.""" deposit = Deposit.create({}) assert deposit['_deposit']['id'] assert 'draft' == deposit.status assert 0 == deposit.revision_id deposit.publish() assert 'published' == deposit.status assert 1 == deposit.revision_id with pytest.raises(PIDInvalidAction): deposit.delete() with pytest.raises(PIDInvalidAction): deposit.clear() with pytest.raises(PIDInvalidAction): deposit.update(title='Revision 2') assert 'published' == deposit.status deposit = deposit.edit() assert 'draft' == deposit.status assert 2 == deposit.revision_id assert 0 == deposit['_deposit']['pid']['revision_id'] with pytest.raises(PIDInvalidAction): deposit.edit() assert 'draft' == deposit.status deposit['title'] = 'Revision 1' deposit.publish() assert 'published' == deposit.status assert 3 == deposit.revision_id assert 0 == deposit['_deposit']['pid']['revision_id'] deposit = deposit.edit() assert 'draft' == deposit.status assert 4 == deposit.revision_id assert 1 == deposit['_deposit']['pid']['revision_id'] deposit['title'] = 'Revision 2' deposit.commit() assert 5 == deposit.revision_id (_, record) = deposit.fetch_published() record_schema_before = record['$schema'] record_json = deepcopy(record.model.json) deposit = deposit.discard() assert 'published' == deposit.status assert 'Revision 1' == deposit['title'] assert 6 == deposit.revision_id (_, record) = deposit.fetch_published() record_schema_after = record['$schema'] assert record_schema_before == record_schema_after assert record_json == record.model.json
def deposit(app_deposit, es, users, location, db): """Get new deposit with files.""" record = {'title': 'fuu'} with app_deposit.test_request_context(): login_user(users[0]) deposit = Deposit.create(record) deposit.commit() db.session.commit() sleep(2) return deposit
def test_create_deposit_index(db, es): """Test if deposit index is created.""" deposit_index_name = 'deposits-records-lhcb-v1.0.0' Deposit.create({ '_deposit': { 'status': 'draft', 'pid': { 'type': 'recid', 'value': '1' }, 'id': 1 } }) db.session.commit() current_search.flush_and_refresh(deposit_index_name) res = current_search.client.search(index=deposit_index_name) # Make sure the '_deposit' is added in the record assert '_deposit' in res['hits']['hits'][0]['_source']
def deposit(app, es, users, location): """New deposit with files.""" record = {"title": "fuu"} with app.test_request_context(): datastore = app.extensions["security"].datastore login_user(datastore.find_user(email=users[0]["email"])) deposit = Deposit.create(record) deposit.commit() db.session.commit() sleep(2) return deposit
def test_create_deposit_cms_questionnaire_index(db, es, deposit_index): """Test if deposit cms questionnaire index is created.""" deposit_index_name = deposit_index + '-' + 'cms-questionnaire-v0.0.1' Deposit.create({ '$schema': 'https://localhost:5000/schemas/deposits/records/cms-questionnaire-v0.0.1.json', '_deposit': { 'status': 'draft', 'pid': { 'type': 'recid', 'value': '1' }, 'id': '0a7dac44ac234fd39d941fa14bae63c3' } }) db.session.commit() current_search.flush_and_refresh(deposit_index_name) res = current_search.client.search(index=deposit_index_name) assert 'id' in res['hits']['hits'][0]['_source']['_deposit']
def deposit(app, es, users, location): """New deposit with files.""" record = { 'title': 'fuu' } with app.test_request_context(): login_user(users[0]) deposit = Deposit.create(record) deposit.commit() db_.session.commit() sleep(2) return deposit
def deposit(app, es, users, location): """New deposit with files.""" record = { 'title': 'fuu' } with app.test_request_context(): datastore = app.extensions['security'].datastore login_user(datastore.find_user(email=users[0]['email'])) deposit = Deposit.create(record) deposit.commit() db.session.commit() sleep(2) return deposit
def test_delete(app, db, fake_schemas): """Test simple delete.""" deposit = Deposit.create({}) pid = deposit.pid assert deposit['_deposit']['id'] assert 'draft' == deposit['_deposit']['status'] assert 0 == deposit.revision_id deposit.delete() with pytest.raises(NoResultFound): Deposit.get_record(deposit.id) with pytest.raises(PIDInvalidAction): deposit.publish(pid=pid)
def test_delete(app, db, fake_schemas, location): """Test simple delete.""" deposit = Deposit.create({}) pid = deposit.pid assert deposit["_deposit"]["id"] assert "draft" == deposit.status assert 0 == deposit.revision_id deposit.delete() with pytest.raises(NoResultFound): Deposit.get_record(deposit.id) with pytest.raises(PIDInvalidAction): deposit.publish(pid=pid)
def test_delete(app, fake_schemas, location): """Test simple delete.""" deposit = Deposit.create({}) pid = deposit.pid assert deposit['_deposit']['id'] assert 'draft' == deposit.status assert 0 == deposit.revision_id deposit.delete() with pytest.raises(NoResultFound): Deposit.get_record(deposit.id) with pytest.raises(PIDInvalidAction): deposit.publish(pid=pid)
def test_simple_flow(app, db, fake_schemas, location): """Test simple flow of deposit states through its lifetime.""" deposit = Deposit.create({}) assert deposit['_deposit']['id'] assert 'draft' == deposit['_deposit']['status'] assert 0 == deposit.revision_id deposit.publish() assert 'published' == deposit['_deposit']['status'] assert 1 == deposit.revision_id with pytest.raises(PIDInvalidAction): deposit.delete() with pytest.raises(PIDInvalidAction): deposit.clear() with pytest.raises(PIDInvalidAction): deposit.update(title='Revision 2') assert 'published' == deposit['_deposit']['status'] deposit = deposit.edit() assert 'draft' == deposit['_deposit']['status'] assert 2 == deposit.revision_id assert 0 == deposit['_deposit']['pid']['revision_id'] with pytest.raises(PIDInvalidAction): deposit.edit() assert 'draft' == deposit['_deposit']['status'] deposit['title'] = 'Revision 1' deposit.publish() assert 'published' == deposit['_deposit']['status'] assert 3 == deposit.revision_id assert 0 == deposit['_deposit']['pid']['revision_id'] deposit = deposit.edit() assert 'draft' == deposit['_deposit']['status'] assert 4 == deposit.revision_id assert 1 == deposit['_deposit']['pid']['revision_id'] deposit['title'] = 'Revision 2' deposit.commit() assert 5 == deposit.revision_id deposit = deposit.discard() assert 'Revision 1' == deposit['title'] assert 6 == deposit.revision_id
def test_publish_merge_conflict(app, db, es, users, location, deposit, json_headers, fake_schemas): """Test publish with merge conflicts.""" with app.test_request_context(): with app.test_client() as client: user_info = dict(email=users[0].email, password='******') # login res = client.post(url_for_security('login'), data=user_info) # create a deposit deposit = Deposit.create({"metadata": { "title": "title-1", }}) deposit.commit() db.session.commit() # publish deposit.publish() db.session.commit() # edit deposit = deposit.edit() db.session.commit() # simulate a externally modification rid, record = deposit.fetch_published() rev_id = record.revision_id record.update({'metadata': { "title": "title-2.1", }}) record.commit() db.session.commit() assert rev_id != record.revision_id # edit again and check the merging deposit.update({"metadata": { "title": "title-2.2", }}) deposit.commit() current_search.flush_and_refresh('_all') deposit_id = deposit.pid.pid_value res = client.post( url_for('invenio_deposit_rest.depid_actions', pid_value=deposit_id, action='publish'), ) assert res.status_code == 409
def test_files_property(app, db, fake_schemas, location): """Test deposit files property.""" with pytest.raises(MissingModelError): Deposit({}).files deposit = Deposit.create({}) assert 0 == len(deposit.files) assert "invalid" not in deposit.files with pytest.raises(KeyError): deposit.files["invalid"] bucket = deposit.files.bucket assert bucket # Create first file: deposit.files["hello.txt"] = BytesIO(b"Hello world!") file_0 = deposit.files["hello.txt"] assert "hello.txt" == file_0["key"] assert 1 == len(deposit.files) # Update first file with new content: deposit.files["hello.txt"] = BytesIO(b"Hola mundo!") file_1 = deposit.files["hello.txt"] assert "hello.txt" == file_1["key"] assert 1 == len(deposit.files) assert file_0["version_id"] != file_1["version_id"] # Create second file and check number of items in files. deposit.files["second.txt"] = BytesIO(b"Second file.") assert deposit.files["second.txt"] assert 2 == len(deposit.files) assert "hello.txt" in deposit.files assert "second.txt" in deposit.files # Check order of files. order_0 = [f["key"] for f in deposit.files] assert ["hello.txt", "second.txt"] == order_0 deposit.files.sort_by(*reversed(order_0)) order_1 = [f["key"] for f in deposit.files] assert ["second.txt", "hello.txt"] == order_1 # Try to rename second file to 'hello.txt'. with pytest.raises(Exception): deposit.files.rename("second.txt", "hello.txt") # Remove the 'hello.txt' file. del deposit.files["hello.txt"] assert "hello.txt" not in deposit.files # Make sure that 'second.txt' is still there. assert "second.txt" in deposit.files with pytest.raises(KeyError): del deposit.files["hello.txt"] # Now you can rename 'second.txt' to 'hello.txt'. deposit.files.rename("second.txt", "hello.txt") assert "second.txt" not in deposit.files assert "hello.txt" in deposit.files
def test_files_property(app, fake_schemas, location): """Test deposit files property.""" with pytest.raises(MissingModelError): Deposit({}).files deposit = Deposit.create({}) assert 0 == len(deposit.files) assert 'invalid' not in deposit.files with pytest.raises(KeyError): deposit.files['invalid'] bucket = deposit.files.bucket assert bucket # Create first file: deposit.files['hello.txt'] = BytesIO(b'Hello world!') file_0 = deposit.files['hello.txt'] assert 'hello.txt' == file_0['key'] assert 1 == len(deposit.files) # Update first file with new content: deposit.files['hello.txt'] = BytesIO(b'Hola mundo!') file_1 = deposit.files['hello.txt'] assert 'hello.txt' == file_1['key'] assert 1 == len(deposit.files) assert file_0['version_id'] != file_1['version_id'] # Create second file and check number of items in files. deposit.files['second.txt'] = BytesIO(b'Second file.') assert deposit.files['second.txt'] assert 2 == len(deposit.files) assert 'hello.txt' in deposit.files assert 'second.txt' in deposit.files # Check order of files. order_0 = [f['key'] for f in deposit.files] assert ['hello.txt', 'second.txt'] == order_0 deposit.files.sort_by(*reversed(order_0)) order_1 = [f['key'] for f in deposit.files] assert ['second.txt', 'hello.txt'] == order_1 # Try to rename second file to 'hello.txt'. with pytest.raises(Exception): deposit.files.rename('second.txt', 'hello.txt') # Remove the 'hello.txt' file. del deposit.files['hello.txt'] assert 'hello.txt' not in deposit.files # Make sure that 'second.txt' is still there. assert 'second.txt' in deposit.files with pytest.raises(KeyError): del deposit.files['hello.txt'] # Now you can rename 'second.txt' to 'hello.txt'. deposit.files.rename('second.txt', 'hello.txt') assert 'second.txt' not in deposit.files assert 'hello.txt' in deposit.files
def test_files_property(app, fake_schemas, location): """Test deposit files property.""" with pytest.raises(MissingModelError): Deposit({}).files deposit = Deposit.create({}) assert 0 == len(deposit.files) assert 'invalid' not in deposit.files with pytest.raises(KeyError): deposit.files['invalid'] bucket = deposit.files.bucket assert bucket # Create first file: deposit.files['hello.txt'] = BytesIO(b'Hello world!') file_0 = deposit.files['hello.txt'] assert 'hello.txt' == file_0['key'] assert 1 == len(deposit.files) # Update first file with new content: deposit.files['hello.txt'] = BytesIO(b'Hola mundo!') file_1 = deposit.files['hello.txt'] assert 'hello.txt' == file_1['key'] assert 1 == len(deposit.files) assert file_0['version_id'] != file_1['version_id'] # Create second file and check number of items in files. deposit.files['second.txt'] = BytesIO(b'Second file.') assert deposit.files['second.txt'] assert 2 == len(deposit.files) assert 'hello.txt' in deposit.files assert 'second.txt' in deposit.files # Check order of files. order_0 = [f['key'] for f in deposit.files] assert ['hello.txt', 'second.txt'] == order_0 deposit.files.sort_by(*reversed(order_0)) order_1 = [f['key'] for f in deposit.files] assert ['second.txt', 'hello.txt'] == order_1 # Try to rename second file to 'hello.txt'. with pytest.raises(Exception): deposit.files.rename('second.txt', 'hello.txt') # Remove the 'hello.txt' file. del deposit.files['hello.txt'] assert 'hello.txt' not in deposit.files # Make sure that 'second.txt' is still there. assert 'second.txt' in deposit.files with pytest.raises(KeyError): del deposit.files['hello.txt'] # Now you can rename 'second.txt' to 'hello.txt'. deposit.files.rename('second.txt', 'hello.txt') assert 'second.txt' not in deposit.files assert 'hello.txt' in deposit.files