こんにちは。COUNTERWORKSアドベントカレンダー13日目担当の疋田です。 先月からエンジニアとしてJOINしました。現在、業務ではshopcounterというサービスのRailsアプリケーション開発や日々の運用、データ集計や分析を元にしたプロダクトの改善などをメインで行っています。 スタートアップのエンジニアを経験していく中で、常に素早くPDCA回してユーザからのフィードバックをプロダクトに反映することが重要になってくるため、エンジニアとしてはコードの変更のしやすさとか捨てやすさ、読みやすさってかなり重要だなーと改めて強く思ってます。 今回は3年くらいRailsやってきた中でちょっとずつ溜まってきたメンテするときこういうコード辛かったなって部分を共有できたらなと思います。 ちなみに、これらはすべて今までの自分自身もやっていた時期があるコードであり、反省の意味も込めて書いてみます。
![Railsでやってしまいがちな保守性を下げてしまうコードとその解決策 - Qiita](https://cdn-ak-scissors.b.st-hatena.com/image/square/56b0bce89519f94926f5e0262d43a58cb42c9228/height=288;version=1;width=512/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Fadvent-calendar-ogp-background-f625e957b80c4bd8dd47b724be996090.jpg%3Fixlib%3Drb-4.0.0%26w%3D1200%26mark64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9UmFpbHMlRTMlODElQTclRTMlODIlODQlRTMlODElQTMlRTMlODElQTYlRTMlODElOTclRTMlODElQkUlRTMlODElODQlRTMlODElOEMlRTMlODElQTElRTMlODElQUElRTQlQkYlOUQlRTUlQUUlODglRTYlODAlQTclRTMlODIlOTIlRTQlQjglOEIlRTMlODElOTIlRTMlODElQTYlRTMlODElOTclRTMlODElQkUlRTMlODElODYlRTMlODIlQjMlRTMlODMlQkMlRTMlODMlODklRTMlODElQTglRTMlODElOUQlRTMlODElQUUlRTglQTclQTMlRTYlQjElQkElRTclQUQlOTYmdHh0LWNvbG9yPSUyMzNBM0MzQyZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT01NiZ0eHQtY2xpcD1lbGxpcHNpcyZ0eHQtYWxpZ249bGVmdCUyQ21pZGRsZSZzPTcxNzk2NDU4NTkzNzQ4MmZhYmU0NDM5MzVkZWMwZGRj%26mark-x%3D142%26mark-y%3D151%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTYxNiZ0eHQ9JTQwaDFraXRhJnR4dC1jb2xvcj0lMjMzQTNDM0MmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9MzYmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz0xZWVkZDVkM2E0ZjA0NmVmODZlYTk0ZjA4MWE2OWZjYw%26blend-x%3D142%26blend-y%3D491%26blend-mode%3Dnormal%26s%3D728e89f9b482ab917829606e21707a99)