A free, once-weekly Scala news flash. Easy to unsubscribe. Goes out every Thursday.
March 14th, 2019, ISSUE 265


Testing Incrementally with ZIO Environment

In this post, I’m going to show you how to use environmental effects to achieve testability. I hope to demonstrate that environmental effects provide easier and more incremental testability—all without sacrificing teachability, abstraction, or type inference.
John A. De Goes (@jdegoes)
Using Scala in the Cloud: A Guide to Amazon EC2 Instance Types

We ran a number of Scala compilation benchmarks and look at what Amazon instance type is the fastest and what offers the best cost per build.
Iulian Dragoș (@jaguarul)
Finally Tagless - Not Quite Dead Yet

Where one sees death, I see the rise of new, possibly more ergonomic, way of doing dependency injection in Scala.
Daniel Beskin
Functional Testing with Tagless-Final

We’ve explored several methods of testing “real-world” applications that are written in the tagless-final style.
Amitay Horwitz (@amitayh)
Monad Transformers aren’t hard!

Today we crafted couple of monad transformers like OptionT, EitherT, got to know that ListT is not a monad, covered that FutureT cannot be implemented without blocking.
Alexander Zaidel
The Functional Scala Concurrency Challenge

Instead of a circuit breaker, I want you to build a tap, which adjusts the flow of requests continuously through the tap.
John A. De Goes (@jdegoes)
Machine Learning with Scala in Google Colaboratory

In this blog post, we’ll see how to set up Scala to run inside Google Colab, and then take a look at a few examples of machine learning (including with GPU acceleration) with Scala inside Colab notebooks.
Shadaj Laddad (@ShadajL)
Rapid and Highly Scalable Development Using Scala and Lagom

The following blog posts will outline the thought process and the problems solved along the way.
Corey Auger (@coreyauger)
Context bound vs Implicit evidence: Performance

In a recent pull request review at work I suggested using context bound to declare effect capabilities instead of implicit values as this is what I see the most in OSS projects and it has also been my preference for a while.
Gabriel Volpe (@volpegabriel87)
Managing State in Akka Actors

Learn how to get rid of the “var” while maintaining a state as a behaviour change.
Tomer Shaiman (@tshaiman)
Typeclasses for Beginners

As a Scala developer, I had always heard about Typeclasses, and it seemed really hard to understand, but I’ll try to simplify it so much so other beginners can easily understand this great feature in Scala.
Orji Samuel
Simple HTTP Server With Scalatra In 20 Lines Of Code

A short example demonstrating how easy it is to build a web service with Scalatra.
Iev Strygul
Implementing deep learning from scratch. Scala example.

Neural networks can be easily built without dedicated libraries.
Seva Dolgopolov (@seva_dolgopolov)
MapR-DB Spark Connector Performance Tests

One of the questions we had during the implementation of our connector was related to how fast our connector is compared to the official connector.
Nicolas A Perez (@anicolaspp)


Adapters, Bridges & Typeclasses in Scala

Object Oriented languages implement ad hoc polymorphism via subtypes. In this video we will see how functional languages achieve similar results with type classes.
DevInsideYou (@DevInsideYou)


ScalaUA, Kiev, Ukraine, March 29-30

Use promo code ScalaTMS%_ScAlAUA-2019-29-30 for 20% discount for our readers!
ScalaUA (@ScalaUA_Conf)
Scalar, Warsaw, Poland April 5-6

Join the next edition of the largest Scala conference in central Europe!
SoftwareMill (@softwaremill)
flatMap(Oslo), May 8-9

Use promo code SCALATIMES for a discount for our readers!
flatMap(Oslo) (@flatmaposlo)
CFP for Lambda World, Cádiz, Spain, October 17th - 18th

Deadline for submissions is June 1st.
Lambda World (@lambda_world)
CFP & free ticket for BeeScala, 21-23 November, Ljubljana

Answer the question: "What is the idea behind the BeeScala name?", send your reply to info@bee-scala.org by 31st of March. For some lucky person, there's one free ticket waiting!
Bee Scala (@BeeScalaConf)
CFP for NEScala 2019

This year, NEScala is back in Philadelphia, April 1st through 3rd.
NEScala (@nescalas)



Idiomatic CBOR (de)serialization in Scala.
Mathias Doenitz (@sirthias)

A framework to create embedded Domain-Specific Languages in Scala.
Yang Bo
quill 3.1.0

Quill provides a QDSL to express queries in Scala and execute them in a target language. Version 3.1.0 adds support for Oracle, Cassandra + Lagom, and improved modularization.
Quill contributors


Scala Times banners?

Want one? Click here
Scala Times stickers?

Want one? Let us know or tweet @scalatimes.

  1. Scala Times Issue #275

    Tagless unions in scala 2.12. Combine IntelliJ IDEA with Hydra for the fastest Scala development experience. TMWL April’19  - qubits, scripting Google Apps & Scala tricks. Performant Functional Programming to the max with ZIO.

  2. Scala Times Issue #274

    AST playground: recursion schemes and recursive data. Rethinking Streaming Workloads with Akka Streams: Part I. Sharing is Caring!. A Scala tutorial for Java developers. Scala: Useful User Information + Why you should consider the Language.

  3. Scala Times Issue #273

    Community and Communication. Futures Made Easy with Scala. Scala: Useful User Information + Why you should consider the Language. Using 47 Degree's Fetch library with ZIO. Scala Compilation Got 5x Faster With Triplequote Hydra.

  4. Scala Times Issue #272

    The little gems of Scala standard library. Practical fiber safety (and how Concurrent implies Parallel). Typelevel Sustainability Program Announcement. Homegrown #Scala Collections - ScalaCheck / ScalaTest Integration. Alphabet Soup: Lensing, for free.

  5. Scala Times Issue #271

    ZIO & Cats Effect: A Match Made in Heaven. Concurrency is complicated. An introduction to Law Testing in Scala. Celebrating 10 Years of Akka. Alphabet Soup: Type-level transformations.

  6. Scala Times Issue #270

    Akka 2.6 roadmap. Extending MapR Database Queries Using Scala Polymorphic Types. Marvels of functional programming: Composing effects with monads. Traverse your HLists for fun and profit. Did Functional Programming get it wrong?.

  7. Scala Times Issue #269

    Scalar 2019 whiteboard voting. 38 lines of code towards better data validation in Scala. Scala: Internals and Intermediates. Hacker News API Part 5. Scala Ordering Crash Course.

  8. Scala Times Issue #268

    Functional Hangman with ZIO. Scala or Go: Tastes Great or Less Filling?. An Example of Free Monads and Optimization. Homegrown Scala Collections - Part 29 - Are Views Typeclasses?. Scalar, Warsaw, Poland April 5th - 6th.

  9. Scala Times Issue #267

    Bloop’s compiler performance is ~29% faster than SBT. Fourth batch of Scala 3 SIPs. Functional Hangman with ZIO. Scala: Understanding Variance. Fun with mutually-recursive typeclass resolution.

  10. Scala Times Issue #266

    The RedMonk Programming Language Rankings: January 2019. A monad is not a burrito. Joins in Apache Spark - Part 3. Scala sbt Project Directory Structure. Scala Snippets #1: Instantiable Implicits.

  11. Scala Times Issue #265

    Testing Incrementally with ZIO Environment. Finally Tagless - Not Quite Dead Yet. Functional Testing with Tagless-Final. Monad Transformers aren’t hard!. The Functional Scala Concurrency Challenge.

  12. Scala Times Issue #264

    Final Tagless seen alive. Effectful Episode with John de Goes. State vs Stateful Actor. Phil Bagwell Nominations. Introduction to Akka Streams.

  13. Scala Times Issue #263

    Describe, then interpret: HTTP endpoints using tapir. Vue.js with Playframework. Mu-RPC: defining messages and services. Validate Service Configuration in Scala. Modern Systems Programming And Scala Native With Richard Whaling.

  14. Scala Times Issue #262

    Is your Scala object always a singleton?. Freer doesn’t come for free. Maintaining Binary Compatibility in Scala. Anatomy of functors and category theory. A little Scala 'sed' class.

  15. Scala Times Issue #261: from Scala with love

    Aecor — Purely functional event sourcing in Scala. Part 5. Homegrown #Scala Collections - Foldable Maps. Kubernetes Liveness and Readiness Probes Revisited. Streams and Resource Safety | Akka. Assemble messages from Akka Actors.

  16. Scala Times Issue #260

    Cats Ecosystem Community Survey 2018 Results. Thread Pool Best Practices with ZIO. Purely functional parallelism in Scala. Finatra meets Ammonite. Typed Supervision: why the changes?.

  17. Scala Times Issue #259

    State of Scala compilation time in 2018. Low-memory symbol indexing with bloom filters. Finally: Top-level Definitions. Why you should think about functional programming. Toward a polyglot James server….

  18. Scala Times Issue #258

    Scala Days 2019 - Celebrating Collaborative Success. Scala community build grows, adds Scala 2.13 and JDK 11. Type-checked triple equals: Scala test. Using Scala Plugins From Gradle. Exploring Explicit Nulls in Dotty.

  19. Scala Times Issue #257

    High-Performance Functional Programming Through Effect Rotation. Trampolines for Everything. This month at SoftwareMill we’ve learned — December’18. A Guide to Scala Collections: Exploring Monads in Scala Collections. Spark Custom Stream Sources.

  20. Scala Times Issue #256

    Where is the llama for FS2?. Scala Best Practices - Foreword. Aecor - Purely functional event sourcing in Scala. Part 4b. Postgresql from Spark, how to query?. Error Handling in Akka Actor (with Future).

  21. Scala Times Issue #255

    ADT through the looking glass - lenses, prims and other optics. Hpc with scala and akka Actors. Scala Type Classes - The Name Printer. Evolutionary Algorithms on the JVM via Scala  -  a minimal introduction. Aecor - Purely functional event sourcing in Scala. Part 4a.

  22. Scala Times Issue #254

    Cats Ecosystem Community Survey 2018. Scala Developer Suvey Results 2018. Minutes of the 11th meeting of the Scala Center, Q4 2018. Software as a Reflection of Values With Bryan Cantrill. Dotty: An Alternative to Implicits.

  23. Scala Times Issue #253

    Scala Variables - Syntax, Declaration, Use case, Examples - Leo Benkel. Fast goto definition with low memory footprint · Metals. New Akka Getting Started Guide. Different ways to understand a monad. MOOC: Introduction to programming with dependent types in Scala.

  24. Scala Times Issue #252

    The F-words: functor and friends. Grafter  -  a take on yet another DI library. Anatomy of a Scala quirk. Creating Work Queues with Apache Kafka and Apache Pulsar. Terminus - Cross Platform Terminal Emulator for Sublime Text.

  25. Scala Times Issue #251

    Scala Numerical Performance with Scala Native and Graal. SBT Plugin - How to make it, debug it, improve it?. Better than IO, part 1. Scala and Slick - An Introduction. Category Theory for Programmers: Scala Edition 1.1-RC.

Organizing an event?
Promote it with
Scala Times.
The Scala Times reader?
Get a banner!
Got a tip? Send it in!
Follow us on Twitter.
Curated by SoftwareMill.
We are hiring.
And taking on projects.