Software Engineer - Scala

Input Output


1 month ago

10/13/2019 10:22:57

Job type: Full-time

Hiring from: Europe

Category: Software Dev


Summary

As a Software Engineer at IOHK you are responsible for writing high-quality code for our products. You have the exciting challenge of working with cutting-edge research and technology with a focus on the market's needs. To support you on this challenge, our products have software architects, product managers, project managers, formal methods specialists and QA test engineers, with whom you must communicate professionally, effectively and efficiently.

Duties

  • Follow agile software development practices

  • Work with teams across multiple time zones

  • Work independently on software development tasks

  • Be proactive and require minimal supervision or mentoring to complete tasks

  • Review specifications produced by architects and formal methods specialists

  • Contribute to the design of algorithms

  • Write clean, straightforward, efficient code that satisfies previously agreed acceptance criteria and specifications

  • Commit often and submit small pull requests frequently

  • Cover your code with unit, property and integration tests when applicable

  • Review the pull requests of your team mates

  • Fix bugs in your own code and in legacy code from others

  • Be available for emergency fixing of severity 1 issues on deployed products

  • Integrate software components and third-party libraries

  • Verify and deploy programs and systems

  • Troubleshoot, debug and upgrade existing software

  • Write documentation for the code

  • Write technical user manuals

  • Be knowledgeable of distributed and concurrent computation

Key Competencies

  • Write idiomatic code that satisfies the acceptance criteria of a given task

  • Write tests (unit tests, property tests) that provide sufficient and non-superfluous efficient code coverage.

  • Document code and APIs concisely and unambiguously

  • Break down tasks into sub-tasks that are completable in a short amount of time and report completion as required by managers

  • Pragmatically adhere to software engineering principles (modularity, incremental development, no premature optimization, no feature creep, no speculative generality, ...)

Education / Experience

  • Degree in Computer Science is desirable but not essential

  • A minimum of 2-3 years development experience (professional or otherwise) in the required language (Scala)

  • Experience working with Git and Git workflow

  • Practical experience with Agile software development methods

  • Knowledge of functional and object-oriented programming paradigms

Specialist Skills

  • Skills relevant for a software engineer specialized in Scala

  • Advanced knowledge of the Scala type system.

  • Familiarity with frameworks such as Akka, Monix, Shapeless, Scalacheck & Scalatest.

  • Practical experience in the use of profilers, VM and GC tuning. 

Please mention that you come from Remotive when applying for this job.

Help us maintain Remotive! If this link is broken, please just click to report dead link!

similar jobs

  • Datasembly (US and Canada only)
    4 weeks ago

    Datasembly is a B2B startup that builds next-generation pricing and promotion analysis tools for the grocery & retail industry. Our tools are used by some of the largest names in grocery and retail to create pricing strategies and set price points on thousands of consumer products. All of this is powered by our data, the most comprehensive pricing and product data in the industry.


    As a Full Stack Software Engineer, you will have the opportunity to work as part of a small team and contribute to all parts of the Datasembly technology stack, including data collection, data processing and analytics, backend web development, and frontend web development.


    Technologies

    * Scala

    * Typescript, React, Redux, D3

    * Apache Spark, Google Cloud Dataflow

    * MySQL, BigQuery


    Benefits

    * Equity

    * Health insurance

    * Coworking stipend

    * Develop new tools and solutions from the ground up

    * Remote work and flexible working hours

    * Opportunity to have a large impact at a startup


    To apply, send an email to: [email protected]

  • Role overview

    We are looking for a skilled consultant with a proven track record for high quality and impact delivery. A true craftsperson with experience using elements of the Lightbend Reactive Platform (Java/Scala, Akka, Play, Lagom) who also enjoys breaking down tough problems, and enabling clients to deliver critical solutions.

    Responsibilities:

    • Advise, assist and support software developers, architects, product and business owners to evolve architectures and design solutions.

    • Consult with clients in mid-size to large organizations to integrate elements of the Lightbend stack into their environment.

    • Actively develop software using Java, Scala, Akka, Lagom and Play Framework.

    • Enable our clients to successfully design and implement software solutions based on the Reactive Platform through workshops, mentoring, code reviews, etc.

    • Opportunity to travel extensively.

    • Candidates can potentially live anywhere in North America. This is much more than a coding position - we are looking for true consultants with a substantial technical background.

    Qualifications:

    You

    • are a developer and evangelist of the Lightbend Reactive Platform; Scala, Akka, Play, Java

    • have experience in distributed architecture and functional programming concepts.

    • have a consulting background and experience working with multiple clients.

    • are a voracious learner, ready to take on new technologies and techniques quickly and constantly.

    • have excellent written and verbal communication skills in at least English.

    • are skillful at interacting and working with people; working with a self-organized lean and agile team to mitigate project risks, manage effort and ensure quality.

    • are dedicated to best practices such as automated testing, code reviews, continuous integration, and continuous deployment.

    • are biased towards action on tough problems and issues, and focused on your client's success.

    • are an agent of change, constantly learning and seeking better outcomes.

    • are passionate about enabling others to adopt new technologies.

    • have experienced many different kinds of projects and methodologies, and know the difference between the effective and the hype.

    • hold at least a Bachelor's degree or equivalent experience.

    • have at least 2 years experience with relevant JVM-based languages and systems.

    • be a U.S. or Canadian Citizen or Permanent Resident

  • 1 month ago

    As part of our engineering team you will be responsible for building our product, an advanced machine learning algorithm within search personalization for e-commerce. As demand for our product continues to increase, we are on a journey to grow the team substantially in 2019. We’d love for you to join us.

    About the role:

    You will be part of a small team that moves fast and iterates. We do weekly sprints, code reviews, testing, and put a lot of emphasis on code style, cleanliness and robustness. You will get to work with amazing engineers specializing in machine learning and distributed systems.

    Your responsibilities include:

    • Managing and improving Findify’s data pipelines - a crucial responsibility for us as Findify collects millions of data points every day to feed our machine learning algorithms

    • Enhancing some of the critical components of our system to successfully integrate our customers’ products and improve our search capabilities

    • Actively contributing to the overall design of our infrastructure and the application of our product vision

    About you:

    You are a creative problem-solver with passion for programming and building scalable architectures.

    You are:

    • Initiative-taking; you are self-motivated, a doer, and can drive projects from start to finish

    • A team-player; you are comfortable working with different styles and believe (like us) that together we achieve much more than alone

    • Driven; you are used to working hard to achieve a goal you care about and running several projects in parallel

    • A great communicator; you are comfortable in communicating in English both written and oral, including leading meetings, selling your ideas and storytelling

    You have:

    • A BSc or MSc in Computer Science or related technical discipline

    • At least 3 years of Scala work experience

    • Experience with relational database systems such as PostgreSQL

    • Familiarity with Akka Stream, Akka HTTP or Flink

    • Experience with Git

    • Working knowledge with Linux/Unix

    We’d be extra impressed if you also have:

    • Experience with AWS / key-value databases such as Cassandra / data-mining / machine learning / search frameworks such as Lucene / e-commerce platforms

    • Dev-ops skills

    • Experience in working in/with remote teams

    • Experience in working in agile/lean methodologies

    • A side project or blog that showcases your passion

    • Location: remote. Flexible within timezone CET +/-2

    We believe that the more inclusive we are, the better products we build and the better we are able to serve our customers. Women and other minorities under-represented in tech are strongly encouraged to apply.

Remotive can help!

Not sure how to apply properly to this job? Watch our live webinar « 3 Mistakes to Avoid When Looking For A Remote Startup Job (And What To Do Instead) ».

Interested to chat with Remote workers? Join our community!