Skip to content

Commit

Permalink
Merge branch 'fix-experiments-autocomplete' into implement-autocomplete
Browse files Browse the repository at this point in the history
  • Loading branch information
Iuliana Voinea committed Dec 11, 2017
2 parents 32460aa + 7203878 commit 482fb69
Show file tree
Hide file tree
Showing 5 changed files with 124 additions and 149 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ define([
this.dataEngine = new Bloodhound({
name: 'affiliations',
remote: {
url: '/api/institutions/_suggest?affiliation:%QUERY',
url: '/api/institutions/_suggest?affiliation=%QUERY',
filter: function(response) {
return $.map(response.affiliation[0].options, function(el) { return el.payload });
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,11 +30,11 @@ define([
this.dataEngine = new Bloodhound({
name: 'experiments',
remote: {
url: '/api/experiments?q=experimentautocomplete:%QUERY*',
url: '/api/experiments/_suggest?experiment=%QUERY',
filter: function(response) {
return response.hits.hits.sort(function (x, y) {
var x_title = x.metadata.legacy_name,
y_title = y.metadata.legacy_name;
return response.experiment[0].options.sort(function (x, y) {
var x_title = x.text,
y_title = y.text;

return x_title.localeCompare(y_title);
});
Expand All @@ -49,7 +49,7 @@ define([
this.$element = $element;

var suggestionTemplate = Hogan.compile(
'<strong>{{ display_name }}</strong><br>'
'<strong>{{ text }}</strong><br>'
);

this.$element.typeahead({
Expand All @@ -67,15 +67,15 @@ define([
}.bind(this));
}.bind(this),
displayKey: function(data) {
return data.metadata.legacy_name;
return data.text;
},
templates: {
empty: function(data) {
return 'Cannot find this experiment in our database.';
},
suggestion: function(data) {
data.metadata.display_name = data.metadata.legacy_name;
return suggestionTemplate.render.call(suggestionTemplate, data.metadata);

return suggestionTemplate.render.call(suggestionTemplate, data);
}.bind(this)
}
});
Expand Down
4 changes: 0 additions & 4 deletions inspirehep/modules/records/mappings/records/experiments.json
Original file line number Diff line number Diff line change
Expand Up @@ -129,9 +129,6 @@
},
"type": "object"
},
"experimentautocomplete": {
"type": "string"
},
"experiment_suggest": {
"payloads": true,
"type": "completion"
Expand Down Expand Up @@ -188,7 +185,6 @@
"type": "date"
},
"legacy_name": {
"copy_to": "experimentautocomplete",
"type": "string"
},
"long_name": {
Expand Down
65 changes: 36 additions & 29 deletions inspirehep/modules/records/receivers.py
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,7 @@ def enhance_after_index(sender, json, *args, **kwargs):
populate_affiliation_suggest(sender, json, *args, **kwargs)
populate_author_count(sender, json, *args, **kwargs)
populate_earliest_date(sender, json, *args, **kwargs)
populate_experiment_suggest(sender, json, *args, **kwargs)
populate_inspire_document_type(sender, json, *args, **kwargs)
populate_name_variations(sender, json, *args, **kwargs)
populate_title_suggest(sender, json, *args, **kwargs)
Expand Down Expand Up @@ -262,35 +263,6 @@ def populate_conference_suggest(sender, json, *args, **kwargs):
})


def populate_experiment_suggest(sender, json, *args, **kwargs):
"""Populate the ``experiment_suggest`` field of Experiments records."""
if 'experiments.json' not in json.get('$schema'):
return

experiment_paths = [
'legacy_name',
'long_name',
'name_variants',
]

input_values = [el for el in chain.from_iterable(
[force_list(get_value(json, path)) for path in experiment_paths]) if el]

legacy_name = json.get('legacy_name', '')

record = get_value(json, 'self.$ref', '')

json.update({
'experiment_suggest': {
'input': input_values,
'output': legacy_name,
'payload': {
'$ref': record,
}
},
})


def populate_inspire_document_type(sender, json, *args, **kwargs):
"""Populate the ``facet_inspire_doc_type`` field of Literature records."""
if 'hep.json' not in json.get('$schema'):
Expand Down Expand Up @@ -508,6 +480,41 @@ def populate_earliest_date(sender, json, *args, **kwargs):
json['earliest_date'] = result


def populate_experiment_suggest(sender, json, *args, **kwargs):
"""Populates experiment_suggest field of experiment records."""

if 'experiments.json' not in json.get('$schema'):
return

experiment_paths = [
'accelerator.value',
'collaboration.value',
'experiment.short_name',
'experiment.value',
'institutions.value',
'legacy_name',
'long_name',
'name_variants',
]

input_values = [el for el in chain.from_iterable(
[force_list(get_value(json, path)) for path in experiment_paths]) if el]

legacy_name = json.get('legacy_name', '')

record = get_value(json, 'self.$ref', '')

json.update({
'experiment_suggest': {
'input': input_values,
'output': legacy_name,
'payload': {
'$ref': record,
},
},
})


def populate_name_variations(sender, json, *args, **kwargs):
"""Generate name variations for each signature of a Literature record."""
if 'hep.json' not in json.get('$schema'):
Expand Down
186 changes: 79 additions & 107 deletions tests/unit/records/test_records_receivers.py
Original file line number Diff line number Diff line change
Expand Up @@ -497,113 +497,6 @@ def test_populate_conference_suggest_does_nothing_if_record_is_not_conference():
assert 'conference_suggest' not in record


def test_populate_experiment_suggest_from_legacy_name():
schema = load_schema('experiments')
subschema = schema['properties']['legacy_name']

record = {
'$schema': 'http://localhost:5000/schemas/records/experiments.json',
'legacy_name': 'foo',
'self': {
'$ref': 'http://localhost:5000/api/experiments/bar'
},
}
assert validate(record['legacy_name'], subschema) is None

populate_experiment_suggest(None, record)

expected = {
'input': ['foo'],
'output': 'foo',
'payload': {
'$ref': 'http://localhost:5000/api/experiments/bar'
},
}

result = record['experiment_suggest']

assert expected == result


def test_populate_experiment_suggest_from_legacy_name_from_long_name():
schema = load_schema('experiments')
subschema = schema['properties']['long_name']

record = {
'$schema': 'http://localhost:5000/schemas/records/experiments.json',
'legacy_name': 'foo',
'long_name': 'bar',
'self': {
'$ref': 'http://localhost:5000/api/experiments/bar'
},
}
assert validate(record['long_name'], subschema) is None

populate_experiment_suggest(None, record)

expected = {
'input': ['foo', 'bar'],
'output': 'foo',
'payload': {
'$ref': 'http://localhost:5000/api/experiments/bar'
},
}

result = record['experiment_suggest']

assert expected == result


def test_populate_experiment_suggest_from_legacy_name_from_name_variants():
schema = load_schema('experiments')
subschema = schema['properties']['name_variants']

record = {
'$schema': 'http://localhost:5000/schemas/records/experiments.json',
'legacy_name': 'foo',
'name_variants': [
'bar',
'baz',
],
'self': {
'$ref': 'http://localhost:5000/api/experiments/bar'
},
}
assert validate(record['name_variants'], subschema) is None

populate_experiment_suggest(None, record)

expected = {
'input': ['foo', 'bar', 'baz'],
'output': 'foo',
'payload': {
'$ref': 'http://localhost:5000/api/experiments/bar'
},
}

result = record['experiment_suggest']

assert expected == result


def test_populate_experiment_suggest_does_nothing_if_record_is_not_experiment():
schema = load_schema('experiments')
subschema = schema['properties']['legacy_name']

record = {
'$schema': 'http://localhost:5000/schemas/records/other.json',
'legacy_name': 'foo',
'self': {
'$ref': 'http://localhost:5000/api/experiments/bar'
},
}
assert validate(record['legacy_name'], subschema) is None

populate_experiment_suggest(None, record)

assert 'experiment_suggest' not in record


def test_assign_phonetic_block_handles_ascii_names():
schema = load_schema('hep')
subschema = schema['properties']['authors']
Expand Down Expand Up @@ -784,6 +677,85 @@ def test_populate_earliest_date_from_preprint_date():
assert expected == result


def test_populate_experiment_suggest():
schema = load_schema('experiments')
legacy_name_schema = schema['properties']['legacy_name']
long_name_schema = schema['properties']['long_name']
name_variants_schema = schema['properties']['name_variants']
collaboration_schema = schema['properties']['collaboration']
accelerator_schema = schema['properties']['accelerator']
experiment_schema = schema['properties']['experiment']
institutions_schema = schema['properties']['institutions']

record = {
'$schema': 'http://foo/experiments.json',
'self': {'$ref': 'https://localhost:5000/api/experiments/bar'},
'legacy_name': 'foo',
'long_name': 'foobarbaz',
'name_variants': [
'bar',
'baz',
],
'collaboration': {
'value': 'D0',
},
'accelerator': {
'value': 'LHC',
},
'experiment': {
'short_name': 'SHINE',
'value': 'NA61',
},
'institutions': [
{
'value': 'ICN',
},
],
}

assert validate(record['legacy_name'], legacy_name_schema) is None
assert validate(record['long_name'], long_name_schema) is None
assert validate(record['name_variants'], name_variants_schema) is None
assert validate(record['collaboration'], collaboration_schema) is None
assert validate(record['accelerator'], accelerator_schema) is None
assert validate(record['institutions'], institutions_schema) is None
assert validate(record['experiment'], experiment_schema) is None

populate_experiment_suggest(None, record)

expected = {
'input': [
'LHC',
'D0',
'SHINE',
'NA61',
'ICN',
'foo',
'foobarbaz',
'bar',
'baz',
],
'output': 'foo',
'payload': {
'$ref': 'https://localhost:5000/api/experiments/bar',
}
}

result = record['experiment_suggest']

assert expected == result


def test_populate_experiment_suggest_does_nothing_if_record_is_not_experiment():
json_dict = {
'$schema': 'http://foo/bar.json',
}

populate_experiment_suggest(None, json_dict)

assert 'experiment_suggest' not in json_dict


def test_populate_earliest_date_from_thesis_info_date():
schema = load_schema('hep')
subschema = schema['properties']['thesis_info']
Expand Down

0 comments on commit 482fb69

Please sign in to comment.