{"id":"https://openalex.org/W3006178354","doi":"https://doi.org/10.22152/programming-journal.org/2020/4/10","title":"Robust Contract Evolution in a TypeSafe MicroServices Architecture","display_name":"Robust Contract Evolution in a TypeSafe MicroServices Architecture","publication_year":2020,"publication_date":"2020-02-14","ids":{"openalex":"https://openalex.org/W3006178354","doi":"https://doi.org/10.22152/programming-journal.org/2020/4/10","mag":"3006178354"},"language":"en","primary_location":{"id":"doi:10.22152/programming-journal.org/2020/4/10","is_oa":false,"landing_page_url":"https://doi.org/10.22152/programming-journal.org/2020/4/10","pdf_url":null,"source":{"id":"https://openalex.org/S4210199781","display_name":"The Art Science and Engineering of Programming","issn_l":"2473-7321","issn":["2473-7321"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"The Art, Science, and Engineering of Programming","raw_type":"journal-article"},"type":"article","indexed_in":["arxiv","crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://arxiv.org/pdf/2002.06185","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5016069660","display_name":"Jo\u00e3o Costa Seco","orcid":"https://orcid.org/0000-0002-2840-3966"},"institutions":[{"id":"https://openalex.org/I83558840","display_name":"Universidade Nova de Lisboa","ror":"https://ror.org/02xankh89","country_code":"PT","type":"education","lineage":["https://openalex.org/I83558840"]}],"countries":["PT"],"is_corresponding":true,"raw_author_name":"Jo\u00e3o Costa Seco","raw_affiliation_strings":["Universidade NOVA de Lisboa, Portugal"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Universidade NOVA de Lisboa, Portugal","institution_ids":["https://openalex.org/I83558840"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5024003933","display_name":"Paulo Ferreira","orcid":"https://orcid.org/0000-0003-0942-6289"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Paulo Ferreira","raw_affiliation_strings":["OutSystems, Portugal"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"OutSystems, Portugal","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5012184796","display_name":"Hugo Louren\u00e7o","orcid":"https://orcid.org/0000-0002-3293-9587"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Hugo Louren\u00e7o","raw_affiliation_strings":["OutSystems, Portugal"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"OutSystems, Portugal","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5031885550","display_name":"Carla Ferreira","orcid":"https://orcid.org/0000-0003-3680-7634"},"institutions":[{"id":"https://openalex.org/I83558840","display_name":"Universidade Nova de Lisboa","ror":"https://ror.org/02xankh89","country_code":"PT","type":"education","lineage":["https://openalex.org/I83558840"]}],"countries":["PT"],"is_corresponding":false,"raw_author_name":"Carla Ferreira","raw_affiliation_strings":["Universidade NOVA de Lisboa, Portugal"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Universidade NOVA de Lisboa, Portugal","institution_ids":["https://openalex.org/I83558840"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5054085822","display_name":"L\u00facio Ferr\u00e3o","orcid":null},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Lucio Ferrao","raw_affiliation_strings":["OutSystems, Portugal"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"OutSystems, Portugal","institution_ids":[]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":5,"corresponding_author_ids":["https://openalex.org/A5016069660"],"corresponding_institution_ids":["https://openalex.org/I83558840"],"apc_list":null,"apc_paid":null,"fwci":0.324,"has_fulltext":false,"cited_by_count":2,"citation_normalized_percentile":{"value":0.60436684,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":94},"biblio":{"volume":"4","issue":"3","first_page":null,"last_page":null},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T12127","display_name":"Software System Performance and Reliability","score":1.0,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},"topics":[{"id":"https://openalex.org/T12127","display_name":"Software System Performance and Reliability","score":1.0,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10679","display_name":"Service-Oriented Architecture and Web Services","score":0.9991000294685364,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10639","display_name":"Advanced Software Engineering Methodologies","score":0.9984999895095825,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8156256675720215},{"id":"https://openalex.org/keywords/microservices","display_name":"Microservices","score":0.766093373298645},{"id":"https://openalex.org/keywords/soundness","display_name":"Soundness","score":0.752488911151886},{"id":"https://openalex.org/keywords/software-deployment","display_name":"Software deployment","score":0.518071174621582},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.5059379935264587},{"id":"https://openalex.org/keywords/correctness","display_name":"Correctness","score":0.46279215812683105},{"id":"https://openalex.org/keywords/boilerplate-text","display_name":"Boilerplate text","score":0.45474550127983093},{"id":"https://openalex.org/keywords/service-oriented-architecture","display_name":"Service-oriented architecture","score":0.44530290365219116},{"id":"https://openalex.org/keywords/adaptation","display_name":"Adaptation (eye)","score":0.41573694348335266},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.40417349338531494},{"id":"https://openalex.org/keywords/software-engineering","display_name":"Software engineering","score":0.34780338406562805},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.19082826375961304},{"id":"https://openalex.org/keywords/web-service","display_name":"Web service","score":0.13993284106254578},{"id":"https://openalex.org/keywords/cloud-computing","display_name":"Cloud computing","score":0.10643446445465088}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8156256675720215},{"id":"https://openalex.org/C2778505942","wikidata":"https://www.wikidata.org/wiki/Q18344624","display_name":"Microservices","level":3,"score":0.766093373298645},{"id":"https://openalex.org/C39920170","wikidata":"https://www.wikidata.org/wiki/Q693083","display_name":"Soundness","level":2,"score":0.752488911151886},{"id":"https://openalex.org/C105339364","wikidata":"https://www.wikidata.org/wiki/Q2297740","display_name":"Software deployment","level":2,"score":0.518071174621582},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.5059379935264587},{"id":"https://openalex.org/C55439883","wikidata":"https://www.wikidata.org/wiki/Q360812","display_name":"Correctness","level":2,"score":0.46279215812683105},{"id":"https://openalex.org/C75701414","wikidata":"https://www.wikidata.org/wiki/Q1651672","display_name":"Boilerplate text","level":2,"score":0.45474550127983093},{"id":"https://openalex.org/C57041688","wikidata":"https://www.wikidata.org/wiki/Q220644","display_name":"Service-oriented architecture","level":3,"score":0.44530290365219116},{"id":"https://openalex.org/C139807058","wikidata":"https://www.wikidata.org/wiki/Q352374","display_name":"Adaptation (eye)","level":2,"score":0.41573694348335266},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.40417349338531494},{"id":"https://openalex.org/C115903868","wikidata":"https://www.wikidata.org/wiki/Q80993","display_name":"Software engineering","level":1,"score":0.34780338406562805},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.19082826375961304},{"id":"https://openalex.org/C35578498","wikidata":"https://www.wikidata.org/wiki/Q193424","display_name":"Web service","level":2,"score":0.13993284106254578},{"id":"https://openalex.org/C79974875","wikidata":"https://www.wikidata.org/wiki/Q483639","display_name":"Cloud computing","level":2,"score":0.10643446445465088},{"id":"https://openalex.org/C120665830","wikidata":"https://www.wikidata.org/wiki/Q14620","display_name":"Optics","level":1,"score":0.0},{"id":"https://openalex.org/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.22152/programming-journal.org/2020/4/10","is_oa":false,"landing_page_url":"https://doi.org/10.22152/programming-journal.org/2020/4/10","pdf_url":null,"source":{"id":"https://openalex.org/S4210199781","display_name":"The Art Science and Engineering of Programming","issn_l":"2473-7321","issn":["2473-7321"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"The Art, Science, and Engineering of Programming","raw_type":"journal-article"},{"id":"pmh:oai:arXiv.org:2002.06185","is_oa":true,"landing_page_url":"http://arxiv.org/abs/2002.06185","pdf_url":"https://arxiv.org/pdf/2002.06185","source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"text"},{"id":"pmh:oai:run.unl.pt:10362/142220","is_oa":true,"landing_page_url":"http://hdl.handle.net/10362/142220","pdf_url":null,"source":{"id":"https://openalex.org/S4306400678","display_name":"Universidade Nova de Lisboa's Repository (Universidade Nova de Lisboa)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I83558840","host_organization_name":"Universidade Nova de Lisboa","host_organization_lineage":["https://openalex.org/I83558840"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"article"}],"best_oa_location":{"id":"pmh:oai:arXiv.org:2002.06185","is_oa":true,"landing_page_url":"http://arxiv.org/abs/2002.06185","pdf_url":"https://arxiv.org/pdf/2002.06185","source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"text"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":31,"referenced_works":["https://openalex.org/W178976396","https://openalex.org/W1488556964","https://openalex.org/W1495288145","https://openalex.org/W1527058108","https://openalex.org/W1552587784","https://openalex.org/W1577231857","https://openalex.org/W1859746003","https://openalex.org/W1941670126","https://openalex.org/W1971164151","https://openalex.org/W1980939032","https://openalex.org/W1983417245","https://openalex.org/W2032399648","https://openalex.org/W2037064850","https://openalex.org/W2097565277","https://openalex.org/W2100095098","https://openalex.org/W2110320121","https://openalex.org/W2124919501","https://openalex.org/W2130191210","https://openalex.org/W2151497944","https://openalex.org/W2322013807","https://openalex.org/W2398517065","https://openalex.org/W2403659235","https://openalex.org/W2767635119","https://openalex.org/W2783772958","https://openalex.org/W2794512073","https://openalex.org/W2913703063","https://openalex.org/W2931122162","https://openalex.org/W2954628465","https://openalex.org/W2963026732","https://openalex.org/W4236883605","https://openalex.org/W4241509948"],"related_works":["https://openalex.org/W3181741639","https://openalex.org/W4210334847","https://openalex.org/W4367181468","https://openalex.org/W2767473057","https://openalex.org/W3183504940","https://openalex.org/W4221075750","https://openalex.org/W3183048213","https://openalex.org/W4237290840","https://openalex.org/W3114080539","https://openalex.org/W4206932869"],"abstract_inverted_index":{"Microservices":[0],"architectures":[1,27],"allow":[2,83],"for":[3,84,161,187],"short":[4],"deployment":[5,189],"cycles":[6],"and":[7,53,71,88,147,176,197,221],"immediate":[8],"effects":[9],"but":[10],"offer":[11],"no":[12],"safety":[13],"mechanisms":[14],"when":[15],"service":[16,51,129],"contracts":[17],"need":[18],"to":[19,36,101,123],"be":[20],"changed.":[21],"Maintaining":[22],"the":[23,37,55,77,85,126,162,166,171,177,180,194],"soundness":[24,159],"of":[25,58,79,90,93,107,168,173,179,190,213,215],"microservice":[26,45],"is":[28,33,109,140],"an":[29,211],"error-prone":[30],"task":[31],"that":[32,48,66,116,151,210,217],"only":[34],"accessible":[35],"most":[38],"disciplined":[39],"development":[40],"teams.":[41],"We":[42,61],"present":[43],"a":[44,63,94,135,143,148],"management":[46,181],"system":[47,146,150,196,205],"statically":[49,127],"verifies":[50],"interfaces":[52,108],"supports":[54],"seamless":[56],"evolution":[57,69,78,106],"compatible":[59],"interfaces.":[60,80],"define":[62],"compatibility":[64],"relation":[65],"captures":[67],"real":[68],"patterns":[70],"embodies":[72],"known":[73],"good":[74],"practices":[75],"on":[76],"Namely,":[81],"we":[82],"addition,":[86],"removal,":[87],"renaming":[89],"data":[91,119,202,208],"fields":[92],"producer":[95],"module":[96],"without":[97,192],"breaking":[98,153],"or":[99,200],"needing":[100],"upgrade":[102],"consumer":[103],"services.":[104],"The":[105],"supported":[110],"by":[111,142],"runtime":[112],"generated":[113],"proxy":[114],"components":[115],"dynamically":[117],"adapt":[118],"exchanged":[120,203],"between":[121,204],"services":[122],"match":[124],"with":[125],"checked":[128],"code.The":[130],"model":[131],"was":[132],"instantiated":[133],"in":[134],"core":[136,163],"language":[137,164],"whose":[138],"semantics":[139],"defined":[141],"labeled":[144],"transition":[145],"type":[149],"prevents":[152],"changes":[154],"from":[155],"being":[156],"deployed.":[157],"Standard":[158],"results":[160],"entail":[165],"existence":[167],"adapters,":[169],"hence":[170],"absence":[172],"adaptation":[174,220],"errors":[175],"correctness":[178],"model.":[182],"This":[183],"adaptive":[184],"approach":[185],"allows":[186],"gradual":[188],"modules,":[191],"halting":[193],"whole":[195],"avoiding":[198],"losing":[199],"misinterpreting":[201],"nodes.":[206],"Experimental":[207],"shows":[209],"average":[212],"69%":[214],"deployments":[216],"would":[218],"require":[219],"recompilation":[222],"are":[223],"safe":[224],"under":[225],"our":[226],"approach.":[227]},"counts_by_year":[{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":1}],"updated_date":"2026-06-04T09:04:59.091469","created_date":"2025-10-10T00:00:00"}
