Applying Factory Method and Adapter Patterns for Smart Home Devices

This course is focused on integrating the design patterns we've studied into a practical project: building a smart home system. Throughout this course, you'll learn how to create and adapt various smart home devices using the Factory Method and Adapter patterns. By the end, you will have a solid understanding of how these design patterns can make your smart home system more efficient, modular, and easier to maintain.

In this unit, we explore two essential design patterns: Factory Method and Adapter. These patterns help us create and adapt devices within a smart home system. To effectively implement these patterns, we will build the devices using the Factory Method and then adapt these devices to interact with other parts of the system using the Adapter pattern.

Quick Summary
  1. Factory Method Pattern:

    • Purpose: Encapsulates the creation of objects, making it easier to introduce new object types without altering existing code.
    • Steps:
      • Define a base class (Device).
      • Create specific device classes (Light, Fan) inheriting from the base class.
      • Implement a factory class (DeviceFactory) to generate instances of these devices.
  2. Adapter Pattern:

    • Purpose: Makes incompatible interfaces compatible. Allows objects from different classes to work together.
    • Steps:
      • Define an adapter interface (USPlugInterface).
      • Create adapter classes (LightAdapter, FanAdapter) that implement this interface and adapt the devices (Light, Fan) to the required interface.
Creating Devices with Factory Method Pattern

To begin with, we use the Factory Method pattern in Python to define a base class for our devices, derive specific device classes from this base class, and finally create a factory class responsible for generating instances of these device classes.

Code Implementation

Here is the complete code for implementing the Factory Method pattern:

The factory object is created using the DeviceFactory class. We then use the create_device method to create instances for "light" and "fan". The respective operate methods are called, displaying "Light is turned on" and "Fan is spinning" as the outputs.

Adapting Devices with Adapter Pattern

Now, let's ensure our devices can interact with other parts of the system that expect a different interface. Specifically, we create an adapter to make our devices compatible with a method called plug_into_us_socket.

Code Implementation

Here is the complete code for implementing the Adapter pattern:

We create a Light and a Fan object and then instances of LightAdapter and FanAdapter by passing the respective device objects to their constructors. The plug_into_us_socket method is called on the adapters, which internally call the operate methods of the devices.

Conclusion

Implementing the Factory Method and Adapter patterns in our smart home system allows us to create a variety of devices in a clean and reusable manner. The Factory Method pattern helps in managing the creation of device objects, while the Adapter pattern ensures that these devices can seamlessly interact with different interfaces. This structured approach makes our smart home system more modular, flexible, and easier to maintain and extend in the future.

Sign up
Join the 1M+ learners on CodeSignal
Be a part of our community of 1M+ users who develop and demonstrate their skills on CodeSignal