2
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

ZOZOAdvent Calendar 2023

Day 24

FeatureFlagのIF文多すぎ問題を解決する

Posted at

この記事はZOZOアドベントカレンダー  Series1の24日目の記事です。

アウトカムをどんどん出していくためにFeatureFlagを活用しているチームは多いと思います。

簡単に機能をON/OFFできる仕組みは有用ですし、なにより安心してリリースできるのがいいですよね。(前回と同じこと書いてる・・・)

しかし、FeatureFlagを多様していると、IF文が増えて困ります。

FeatureFlagを活用する上で最も注意すべき点としては、ONにして問題なければできるだけ早くFeatureFlagを削除することですが、顧客の都合や関連システムの都合でなかなかONにすることができない機能もあるかと思います。

そこで、FeatureFlagを使うために有用なパターンを3つ紹介します。ちなみにこの3点は技術顧問でお世話になっているかとじゅんさんにアドバイスをいただいたものになっています。本当にありがとうございます!

1. モジュールごと分けてしまう。

もうモジュールごと分離してしまいましょう。ON用のモジュールとOFF用のモジュールに分けます。不要になったらモジュールごと削除すればOKなので、運用も簡単です。

2. ファクトリパターンを使う

ファクトリパターンを使って分離しましょう。不要になったらクラスを削除するだけなので運用も簡単です。

// Feature.java
public interface Feature {
    void performFeature();
}
// NewFeatureEnabled.java
public class NewFeatureEnabled implements Feature {
    @Override
    public void performFeature() {
        System.out.println("New feature is enabled. Performing new feature actions.");
    }
}

// NewFeatureDisabled.java
public class NewFeatureDisabled implements Feature {
    @Override
    public void performFeature() {
        System.out.println("New feature is disabled. Performing default actions.");
    }
}
// FeatureFactory.java
public class FeatureFactory {
    public static Feature createFeature(boolean isNewFeatureEnabled) {
        if (isNewFeatureEnabled) {
            return new NewFeatureEnabled();
        } else {
            return new NewFeatureDisabled();
        }
    }
}
// MainClass.java
public class MainClass {
    public static void main(String[] args) {
        boolean isNewFeatureEnabled = /* フィーチャーフラグの値を取得するロジック */;

        Feature feature = FeatureFactory.createFeature(isNewFeatureEnabled);
        feature.performFeature();
    }
}

3.ストラテジパターンを使う

2と似てます。ほぼ一緒かもですが、そのあたりは都合の良いように実装できればよいと思います。
同様に削除するのも容易です。

// FeatureStrategy.java
public interface FeatureStrategy {
    void performFeature();
}
// NewFeatureEnabledStrategy.java
public class NewFeatureEnabledStrategy implements FeatureStrategy {
    @Override
    public void performFeature() {
        System.out.println("New feature is enabled. Performing new feature actions.");
    }
}

// NewFeatureDisabledStrategy.java
public class NewFeatureDisabledStrategy implements FeatureStrategy {
    @Override
    public void performFeature() {
        System.out.println("New feature is disabled. Performing default actions.");
    }
}
// FeatureContext.java
public class FeatureContext {
    private FeatureStrategy featureStrategy;

    public FeatureContext(FeatureStrategy featureStrategy) {
        this.featureStrategy = featureStrategy;
    }

    public void performFeature() {
        featureStrategy.performFeature();
    }
}
// MainClass.java
public class MainClass {
    public static void main(String[] args) {
        boolean isNewFeatureEnabled = /* フィーチャーフラグの値を取得するロジック */;

        FeatureStrategy strategy;
        if (isNewFeatureEnabled) {
            strategy = new NewFeatureEnabledStrategy();
        } else {
            strategy = new NewFeatureDisabledStrategy();
        }

        FeatureContext featureContext = new FeatureContext(strategy);
        featureContext.performFeature();
    }
}

重要なのは、フラグを消すときにいかに容易に、詳細を気にすることなくバサッと消すことができるかです。
主要なビジネスロジックではないところに気を使って時間をかけず行ける方法を考えて実装しましょう。

2
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?