def test_literature_create_with_invalid_data(base_app, db, create_pidstore): data = faker.record(with_control_number=True) data["invalid_key"] = "should throw an error" record_control_number = data["control_number"] with pytest.raises(ValidationError): record = LiteratureRecord.create(data) record_pid = PersistentIdentifier.query.filter_by( pid_value=record_control_number).one_or_none() assert record_pid is None
def test_literature_create_with_existing_control_number( base_app, db, create_pidstore): data = faker.record(with_control_number=True) existing_object_uuid = uuid.uuid4() create_pidstore( object_uuid=existing_object_uuid, pid_type="lit", pid_value=data["control_number"], ) with pytest.raises(PIDAlreadyExists): record = LiteratureRecord.create(data)
def test_literature_create(base_app, db): data = faker.record() record = LiteratureRecord.create(data) control_number = str(record["control_number"]) record_db = RecordMetadata.query.filter_by(id=record.id).one() assert record == record_db.json record_pid = PersistentIdentifier.query.filter_by( pid_type="lit", pid_value=str(control_number)).one() assert record.model.id == record_pid.object_uuid assert control_number == record_pid.pid_value
def test_literature_update(base_app, db): data = faker.record(with_control_number=True) record = LiteratureRecord.create(data) assert data["control_number"] == record["control_number"] data.update({"titles": [{"title": "UPDATED"}]}) record.update(data) control_number = str(record["control_number"]) record_updated_db = RecordMetadata.query.filter_by(id=record.id).one() assert data == record_updated_db.json record_updated_pid = PersistentIdentifier.query.filter_by( pid_type="lit", pid_value=str(control_number)).one() assert record.model.id == record_updated_pid.object_uuid assert control_number == record_updated_pid.pid_value