def test_item_modifier_termination(self): context = ConTextComponent(nlp, rules=None, terminations=None) item = ConTextItem("no evidence of", "NEGATED_EXISTENCE", "FORWARD", terminated_by={"POSITIVE_EXISTENCE", "UNCERTAIN"}) context.add([item]) assert item.terminated_by == {"POSITIVE_EXISTENCE", "UNCERTAIN"}
def test_null_modifier_termination(self): context = ConTextComponent(nlp, rules=None, terminations=None) item = ConTextItem("no evidence of", "NEGATED_EXISTENCE", "FORWARD", terminated_by=None) context.add([item]) assert item.terminated_by == set()
def test_is_historical(self): doc = nlp("History of pneumonia.") context = ConTextComponent(nlp, add_attrs=True, rules=None) item_data = [ConTextItem("history of", "HISTORICAL", rule="forward")] context.add(item_data) doc.ents = (doc[-2:-1], ) context(doc) assert doc.ents[0]._.is_historical is True
def test_is_family(self): doc = nlp("Family history of breast cancer.") context = ConTextComponent(nlp, add_attrs=True, rules=None) item_data = [ ConTextItem("family history of", "FAMILY", rule="forward") ] context.add(item_data) doc.ents = (doc[-3:-1], ) context(doc) assert doc.ents[0]._.is_family is True
def test_is_negated(self): doc = nlp("There is no evidence of pneumonia.") context = ConTextComponent(nlp, add_attrs=True, rules=None) item_data = [ ConTextItem("no evidence of", "NEGATED_EXISTENCE", rule="forward") ] context.add(item_data) doc.ents = (doc[-2:-1], ) context(doc) assert doc.ents[0]._.is_negated is True
def test_global_allowed_types2(self): """Check that if the ConTextComponent does not have allowed_types defined and a ConTextItem does, the ConTextItem will not receive the component's value. """ context = ConTextComponent(nlp, rules=None, allowed_types=None) item = ConTextItem("no evidence of", "NEGATED_EXISTENCE", "FORWARD", allowed_types={"PROBLEM"}) context.add([item]) assert item.allowed_types == {"PROBLEM"}
def test_terminate_stops_backward_modifier(self): context = ConTextComponent(nlp, rules=None) item = ConTextItem("is ruled out", "NEGATED_EXISTENCE", "BACKWARD") item2 = ConTextItem("but", "CONJ", "TERMINATE") context.add([item, item2]) doc = nlp("Pt has chf but pneumonia is ruled out") doc.ents = (Span(doc, 2, 3, "PROBLEM"), Span(doc, 4, 5, "PROBLEM")) context(doc) chf, pneumonia = doc.ents assert len(chf._.modifiers) == 0 assert len(pneumonia._.modifiers) > 0
def test_terminate_stops_forward_modifier(self): context = ConTextComponent(nlp, rules=None) item = ConTextItem("no evidence of", "NEGATED_EXISTENCE", "FORWARD") item2 = ConTextItem("but", "TERMINATE", "TERMINATE") context.add([item, item2]) doc = nlp("No evidence of chf but she has pneumonia.") doc.ents = (Span(doc, 3, 4, "PROBLEM"), Span(doc, 7, 8, "PROBLEM")) context(doc) chf, pneumonia = doc.ents assert len(chf._.modifiers) > 0 assert len(pneumonia._.modifiers) == 0
def test_custom_terminate_stops_forward_modifier(self): doc = nlp("negative for flu, positive for pneumonia.") context = ConTextComponent(nlp, rules=None) item = ConTextItem("negative for", "NEGATED_EXISTENCE", rule="FORWARD", terminated_by={"POSITIVE_EXISTENCE"}) item2 = ConTextItem("positive for", "POSITIVE_EXISTENCE", rule="FORWARD") context.add([item, item2]) doc.ents = (Span(doc, 2, 3, "PROBLEM"), Span(doc, 6, 7)) flu, pneumonia = doc.ents context(doc) assert len(flu._.modifiers) == 1 assert len(pneumonia._.modifiers) == 1
def test_on_modifies_false(self): def on_modifies(target, modifier, span_between): return False context = ConTextComponent(nlp, rules=None) item = ConTextItem("no evidence of", "NEGATED_EXISTENCE", on_modifies=on_modifies) context.add([item]) doc = nlp("There is no evidence of pneumonia or chf.") doc.ents = (doc[5:6], doc[7:8]) context(doc) for ent in doc.ents: assert len(ent._.modifiers) == 0
def test_pseudo_modifier(self): item_data = [ ConTextItem("negative", "NEGATED_EXISTENCE"), ConTextItem("negative attitude", "PSEUDO_NEGATED_EXISTENCE", rule="PSEUDO"), ] context = ConTextComponent(nlp, rules=None) context.add(item_data) doc = nlp("She has a negative attitude about her treatment.") doc.ents = (doc[-2:-1], ) context(doc) assert len(doc.ents[0]._.modifiers) == 0 assert len(doc._.context_graph.modifiers) == 1 assert doc._.context_graph.modifiers[ 0].category == "PSEUDO_NEGATED_EXISTENCE"
def test_custom_attributes_value1(self): custom_attrs = { "NEGATED_EXISTENCE": { "is_negated": True }, } try: Span.set_extension("is_negated", default=False) except: pass context = ConTextComponent(nlp, add_attrs=custom_attrs) context.add( [ConTextItem("no evidence of", "NEGATED_EXISTENCE", "FORWARD")]) doc = nlp("There is no evidence of pneumonia.") doc.ents = (doc[-2:-1], ) context(doc) assert doc.ents[0]._.is_negated is True
def test_simple_callback(self, capsys): context = ConTextComponent(nlp, rules=None) def simple_callback(matcher, doc, i, matches): match_id, start, end = matches[i] span = doc[start:end] print("Matched on span:", span) context.add([ ConTextItem("no evidence of", "NEGATED_EXISTENCE", "FORWARD", on_match=simple_callback) ]) doc = nlp("There is no evidence of pneumonia.") context(doc) captured = capsys.readouterr() assert captured.out == "Matched on span: no evidence of\n"