Using Slack like a Slack developer

Take away these best practices from Slack's own engineering teams, from how they use channels to their favorite integrations

How Slack uses Slack

You might have heard Slack’s origin story: It began life as an internal tool that helped a games development company collaborate better. Fast-forward to today, and Slack is used by teams all over the world—and all over the enterprise, from marketing and sales to HR to customer support, not to mention engineering teams. It’s a channel-based messaging platform that brings people, data and tools together in one central place. And it’s highly adaptive, flexing to suit the structures and working styles of all kinds of teams.

Computer icon

To demonstrate the value Slack brings teams, it’s often easier to show rather than tell. As a company with its own engineering teams looking to leverage Slack in everything they do, we thought it made sense to turn the spotlight on ourselves. So here’s the story of how Slack’s developers use Slack every day.

Every team is different, so what works for us won’t necessarily work for everyone. But read on for some insights about our own engineering teams’ use of Slack.

Vertical and horizontal collaboration

No two engineering teams are the same. Your setup will vary depending on your size, structure, industry, whether your engineering teams are building a core product or supporting the wider work of the organization—or both. The list goes on.
Some organizations might have a traditional waterfall team structure, split according to development process chronology: architects, then developers, then testers, and so on.

At Slack, we split our teams according to vertical pillars instead:

  • Platform: The team responsible for external dev-facing features like APIs
  • Core: The team that works on Slack as most users know it: the core product
  • Enterprise: The team that makes sure Slack scales for big businesses
  • Infrastructure: The team responsible for the back-end side of things

Each of these teams has its own goals and processes, but they all have to work together at different times, so collaboration has to be vertical and horizontal. That’s why we have cross-team channels that are project or goal-specific—for managing a feature launch or for end-of-quarter reporting, for example. Then there are function-specific channels, like the one we use for front-end developers to share best practices across teams.

Let’s take a deeper dive into one of these four pillars, the platform team.

How Slack uses Slack: The Platform team 

Each team uses Slack differently (that’s the beauty of it), but the platform team will give you an idea of how we use our own workspace.

Like all of the four main engineering teams at Slack, the platform team has a team channel that serves as its home base. This is where general team announcements happen. All team members are present, and the channel is open to employees from other teams who want to check in. Then each feature in development has its own set of subteam channels. For example, the Block Kit team has the following:

  • #devel-block-kit

Where day-to-day work is discussed and managed by engineers, project managers, designers, testers and others. You’d expect to see things like code merges, design updates and drafts of product specs.

  • #feat-block-kit

Content in this channel relates to discussion about the feature as a whole. Product, design and development agree on what is in or out of scope, nail down specific requirements and make decisions as edge cases arise.

  • #gtm-block-kit

Channels with a “gtm” prefix are where the go-to-market strategy for a new product launch is discussed.

“In the past you might have a load of email notifications about incidents, outages or code updates, but you can’t really do anything with them. In Slack, you see the notification in context, and you can handle it right there.”

Mike BrevoortDirector Software Engineering, Slack

We have triage and escalation channels for managing bug reporting, incidents, outages and more. The PagerDuty app posts incident alerts in an appropriate channel and lets you triage right within Slack.

Almost all our channels are public, and people from other teams with a general interest in what the platform team is building will join. But sometimes we do need private channels. For example, we have a private leadership channel and another for discussing how to cascade important comms to the rest of the team.

PagerDuty integration in Slack posting into channel

How we use Slack apps

When we say “Slack apps,” we’re talking about things like the PagerDuty app we mentioned in the previous section: an app that makes your critical software tools accessible and usable within your Slack workspace.

Here are a few common scenarios for which Slack apps help our teams work smarter.

Deployments

We use Slack apps that funnel push notifications from GitHub and other services. This automates and streamlines communication, leading ultimately to faster, safer code deployments.

Github integration in Slack posting pull requests in channel

Bug tracking

We can preview and address Jira tickets in Slack, without having to find and open the URL.

Form details are pre-filled, so tickets are automatically put into the right place for triage. And we use quick visual cues to speed up our work. For example, we use ⚪,🔵and 🔴emoji to prioritize tickets, and a custom app organizes them based on those priorities.

When someone reviews an item, they use a 👀 reacji. Then a ✅to show that it’s resolved.

2173336094482
feat-block-kit
Add a topic
张语婷
王乐迪
苏奕哲
3
杜子杰10:55 AM

:laptop: Respect Collapse All Images pref for Image Block
Story: PAX-1969
Test run: https://slack.testrail.net
Bugs: none specific to Image Block Kit. However, IOSAPP-14414 impacts that user preference spearately from Block Kit.
QA Status: :green_check_mark:

PAX-1969 Respecting the Collapse images and gifs inline preference on iOS (In QA)

IOSAPP-14414 DMs/MPDMS/Channels | Collapse All Images preference not respected until message pane is reloaded (Triage)

张语婷11:00 AM

I don’t think this was shared previously, even though this was completed earlier this week. Sharing this in here for transparency.

Zoe Maxwell
:laptop:Refactor SMUMessageDelegates; create Block Kit component factory under Slack UI
Story: PAX-2042
Test run: executed as part of iOS regression, 
https://slack.testrail.net
Bugs: none
QA Status: :green_check_mark:
Posted in #platform-qa | Aug 30th, 2018 | View message

Zoe Maxwell
:laptop:Divider Block
Story: PAX-1950

Customer support 

Every Zendesk ticket that’s created is funneled into a relevant Slack channel so it can be easily dealt with in collaboration with teammates.

“We use a lot of apps (both custom and publicly available) in our Slack workspace, but even built-in Slack functionality like reminders are a great way to rally the team and discuss what’s happening today. That simple function has saved us from interrupting individuals with a daily meeting.”

Brian NgoSenior Engineering Manager, Slack
Zendesk automation in Slack channel

Graphs for quick insights 

Instead of logging into other software, you can pull handy graphs right into Slack, spot problems and act quickly to correct them. For example, a graph might monitor your API’s rate of 500 errors and give you an at-a-glance view of a recent spike that could signify a server issue.

Arc daily report for website visitors pushed into Slack channel

 

Some Slack apps we use for DevOps 

Over to you

So there you have it—a snapshot of Slack’s own use of Slack. This is just one example of many. Even within our engineering teams, there are lots of different ways we use our own platform to work more efficiently.

Learn more about building bots, apps, tools and workflows for Slack here, or contact sales for a chat about how your engineering teams can make the most of Slack.

Was this resource useful?

0/600

Awesome!

Thanks so much for your feedback!

Got it!

Thanks for your feedback.

Oops! We're having trouble. Please try again later!