Background: Using feature toggles is a technique that allows developers to either turn a feature on or off with a variable in a conditional statement. Feature toggles are increasingly used by software companies to facilitate continuous integration and continuous delivery. However, using feature toggles inappropriately may cause problems which can have a severe impact, such as code complexity, dead code, and system failure. For example, the erroneous repurposing of an old feature toggle caused Knight Capital Group, an American global financial services firm, to go bankrupt due to the implications of the resultant incorrect system behavior. Aim: The goal of this research project is to aid software practitioners in the use of practices to support software development with feature toggles through an empirical study of feature toggle practice usage by practitioners. Method: We conducted a qualitative analysis of 99 artifacts from the grey literature and 10 peer-reviewed papers about feature toggles. We conducted a survey of practitioners from 38 companies. Results: We identified 17 practices in 4 categories: Management practices, Initialization practices, Implementation practices, and Clean-up practices. We observed that all of the survey respondents use a dedicated tool to create and manage feature toggles in their code. Documenting feature toggle's metadata, setting up the default value for feature toggles, and logging the changes made on feature toggles are also frequently-observed practices. Conclusions: The feature toggle development practices discovered and enumerated in this work can help practitioners more effectively use feature toggles. This work can enable future mining of code repositories to automatically identify feature toggle practices.
翻译:使用特性切换器是一种技术,使开发商可以在有条件的语句中以变数打开或关闭一个特性。软件公司越来越多地使用特性切换器来推动连续整合和连续交付。但是,使用特性切换器不适当地可能造成严重影响的问题,例如代码复杂、代码破损和系统故障。例如,错误地重新标出一个老特性切换器导致美国全球金融服务公司Knight Capital集团,由于由此产生的系统行为不正确而破产。目标:本研究项目的目标是帮助软件从业人员使用各种做法,通过对特性进行实验性研究,从而支持软件的升级,从而支持特性的开发。方法:我们从灰色文献和关于特性切换器的10份同行审查论文中,对99件文物进行了定性分析。我们对38家公司的从业者进行了调查。结果:我们查明了4类中的17种做法:管理做法、初始化做法、实施做法和清洁做法。我们观察到,所有调查对象都使用这一专门工具,通过这些特性切换方法,来创建和记录特性的特性,并管理其特性的特性切换。