====== 4.3.1.3 Replaceability ====== [[dido:public:ra:1.4_req:2_nonfunc:10_portability | Return to Portability ]] ===== About ===== [[dido:public:ra:xapend:xapend.a_glossary:r:replaceability]] occurs when software components are developed using open, well written, standard specifications, usually captured as an [[dido:public:ra:xapend:xapend.a_glossary:a:api]]. The standards can be either technical (i.e., developed by a [[dido:public:ra:xapend:xapend.a_glossary:s:stdorg]]) or [[dido:public:ra:xapend:xapend.a_glossary:d:defactostd| de facto]] (i.e., developed by a for-profit or [[dido:public:ra:xapend:xapend.a_glossary:n:non-profit]] corporation). Replaceability is also a key factor in preventing [[dido:public:ra:xapend:xapend.a_glossary:v:vendorlockin]]. Replaceability is not just about the ability to [[dido:public:ra:xapend:xapend.a_glossary:s:switch|switch]] suppliers and avoid [[dido:public:ra:xapend:xapend.a_glossary:v:vendorlockin]]((**Note:** Vendors are not just proprietary corporations; Open Source projects produce and sell products also. The software might be "free", but the producers are competitors that have the same drive to lock-in customers as the corporations)) of the components, it's also about managing risk to the target system. This is especially true because each component can have its own [[dido:public:ra:xapend:xapend.a_glossary:s:syslifecycle| Lifecycle]] with its own [[dido:public:ra:xapend:xapend.a_glossary:e:eol]] timelines, independent of the target system. In addition to the components' lifecycle, many components are now [[dido:public:ra:xapend:xapend.a_glossary:o:oss]], which can often have forks spawning newer and competing products with similar, but not identical APIs. A recent article describes the __Best Message Queue (MQ) Software__ of 2020. It describes 30 of the "top" [[dido:public:ra:xapend:xapend.a_glossary:m:mq]] [[dido:public:ra:xapend:xapend.a_glossary:m:mom]] software products.(( __Best Message Queue (MQ) Software__, [[https://www.g2.com/]], )): - MuleSoft Anypoint Platform - IBM MQ - Azure Scheduler - Apache Kafka - Google Cloud Pub/Sub - Amazon MQ - RabbitMQ - Apache ActiveMQ - KubeMQ - IBM MQ on Cloud - Azure Queue Storage - Alibaba Message Queue - Alibaba Message Service - CloudAMQP - Intel MPI Library - ZeroMQ - Apache Qpid - Apache RocketMQ - IBM Compose for RabbitMQ - IronMQ - PubSub+ - Red Hat AMQ - TIBCO Enterprise Message Service - Bottomline GTBridge - CloudMQTT - Compose Hosted RabbitMQ - deepestream.io - Enduro/Z - EnMasse - IBM Cloud Pak for Integration Obviously, not all these products have the same API. They definitely do not have the same [[dido:public:ra:xapend:xapend.a_glossary:w:wireprotocol]], so it is very difficult to "mix and match" [[dido:public:ra:xapend:xapend.a_glossary:p:publisher| Publishers]] and [[dido:public:ra:xapend:xapend.a_glossary:s:subscriber| Subscribers]]. In a [[dido:public:ra:xapend:xapend.a_glossary:d:distsystem|distributed system]], this would require all the components within the system to upgrade at the same time, sometimes referred to as a "[[dido:public:ra:xapend:xapend.a_glossary:r:rebootworld]]". And when the upgrades occur, each part of the system requires complete [[dido:public:ra:xapend:xapend.a_glossary:r:regressiontesting]] to make sure that all the parts of the system continue to operate and function according to the specifications. Replaceability is closely related to [[ddsf:private:cookbook:02_body:02_projreq:nonfunctional:10_portability:01_adapt | Adaptability]] and the kinds of Installers /* the rest of this sentence makes no sense. I have no idea how to fix. There's some words missing but I can't guess what they'd be */ [[dido:public:ra:xapend:xapend.a_glossary:a:archdaptability| Architecture]] and [[dido:public:ra:xapend:xapend.a_glossary:s:swadapt]]. Whenever there is an architecture or software adaptability issue, there is probably a Replaceability issue as well. Additionally, the concepts of [[ddsf:private:cookbook:02_body:02_projreq:nonfunctional:10_portability:04_install | Installability]] and Replaceability overlap. The harder a system or a product is to install, the greater the probability it will also be hard to replace. Competitive products within the same domain are ideal candidates for Replaceability. However, replacing products should not just be driven by the cost of acquisition (i.e., purchase price) but also on the [[dido:public:ra:xapend:xapend.a_glossary:t:totalcostown]], which considers the cost throughout the lifecycle of the target system or component including maintenance (see [[dido:public:ra:1.4_req:2_nonfunc:20_maintainability]]). This cost can be tied to other tangential products such as debuggers, [[dido:public:ra:xapend:xapend.a_glossary:p:performance|performance]] monitors, loggers, or any of the [[dido:public:ra:1.4_req:2_nonfunc | Non-Functional Requirements]].(( __Portability Testing Guide with Practical Examples__, Software Testing Help, 30 June 2020, Accessed 31 July 2020, [[https://www.softwaretestinghelp.com/what-is-portability-testing/]] )) ===== DIDO Specifics ===== [[ddsf:private:cookbook:02_body:02_projreq:nonfunctional:10_portability:01_adapt | Return to the Top]] : To be added/expanded in future revisions of the DIDO RA /**=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=- /* To add a discussion page to this page, comment out the line that says ~~DISCUSSION:off~~ */ ~~DISCUSSION:on|Outstanding Issues~~ ~~DISCUSSION:off~~