mirror of
https://github.com/JanDeDobbeleer/oh-my-posh.git
synced 2025-01-15 21:29:24 -08:00
fix(wsl): spotify support
If we are in a WSL environment and tasklist.exe is in our PATH, leverage it to scan for the Spotify.exe window title. Add unit tests and a new mock for env.isWSL
This commit is contained in:
parent
f64a8fa51a
commit
b8d3f5781c
|
@ -7,7 +7,7 @@ sidebar_label: Spotify
|
||||||
## What
|
## What
|
||||||
|
|
||||||
Show the currently playing song in the Spotify MacOS/Windows client.
|
Show the currently playing song in the Spotify MacOS/Windows client.
|
||||||
On Windows, only the playing state is supported (no information when paused/stopped).
|
On Windows/WSL, only the playing state is supported (no information when paused/stopped).
|
||||||
On macOS, all states are supported (playing/paused/stopped).
|
On macOS, all states are supported (playing/paused/stopped).
|
||||||
**Be aware this can make the prompt a tad bit slower as it needs to get a response from the Spotify player.**
|
**Be aware this can make the prompt a tad bit slower as it needs to get a response from the Spotify player.**
|
||||||
|
|
||||||
|
|
|
@ -58,6 +58,7 @@ func TestGetGitOutputForCommand(t *testing.T) {
|
||||||
commandArgs := []string{"symbolic-ref", "--short", "HEAD"}
|
commandArgs := []string{"symbolic-ref", "--short", "HEAD"}
|
||||||
want := "je suis le output"
|
want := "je suis le output"
|
||||||
env := new(MockedEnvironment)
|
env := new(MockedEnvironment)
|
||||||
|
env.On("isWsl", nil).Return(false)
|
||||||
env.On("runCommand", "git", append(args, commandArgs...)).Return(want, nil)
|
env.On("runCommand", "git", append(args, commandArgs...)).Return(want, nil)
|
||||||
env.On("getRuntimeGOOS", nil).Return("unix")
|
env.On("getRuntimeGOOS", nil).Return("unix")
|
||||||
g := &git{
|
g := &git{
|
||||||
|
@ -92,6 +93,7 @@ type detachedContext struct {
|
||||||
|
|
||||||
func setupHEADContextEnv(context *detachedContext) *git {
|
func setupHEADContextEnv(context *detachedContext) *git {
|
||||||
env := new(MockedEnvironment)
|
env := new(MockedEnvironment)
|
||||||
|
env.On("isWsl", nil).Return(false)
|
||||||
env.On("hasFolder", "/rebase-merge").Return(context.rebaseMerge)
|
env.On("hasFolder", "/rebase-merge").Return(context.rebaseMerge)
|
||||||
env.On("hasFolder", "/rebase-apply").Return(context.rebaseApply)
|
env.On("hasFolder", "/rebase-apply").Return(context.rebaseApply)
|
||||||
env.On("hasFolder", "/sequencer").Return(context.sequencer)
|
env.On("hasFolder", "/sequencer").Return(context.sequencer)
|
||||||
|
@ -530,6 +532,7 @@ func TestParseGitStatsInvalidLine(t *testing.T) {
|
||||||
|
|
||||||
func bootstrapUpstreamTest(upstream string) *git {
|
func bootstrapUpstreamTest(upstream string) *git {
|
||||||
env := &MockedEnvironment{}
|
env := &MockedEnvironment{}
|
||||||
|
env.On("isWsl", nil).Return(false)
|
||||||
env.On("runCommand", "git", []string{"--no-optional-locks", "-c", "core.quotepath=false", "-c", "color.status=false", "remote", "get-url", "origin"}).Return(upstream, nil)
|
env.On("runCommand", "git", []string{"--no-optional-locks", "-c", "core.quotepath=false", "-c", "color.status=false", "remote", "get-url", "origin"}).Return(upstream, nil)
|
||||||
env.On("getRuntimeGOOS", nil).Return("unix")
|
env.On("getRuntimeGOOS", nil).Return("unix")
|
||||||
props := &properties{
|
props := &properties{
|
||||||
|
|
|
@ -145,7 +145,8 @@ func (env *MockedEnvironment) stackCount() int {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (env *MockedEnvironment) isWsl() bool {
|
func (env *MockedEnvironment) isWsl() bool {
|
||||||
return false
|
args := env.Called(nil)
|
||||||
|
return args.Bool(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (env *MockedEnvironment) getTerminalWidth() (int, error) {
|
func (env *MockedEnvironment) getTerminalWidth() (int, error) {
|
||||||
|
|
|
@ -1,7 +0,0 @@
|
||||||
//go:build !darwin && !windows
|
|
||||||
|
|
||||||
package main
|
|
||||||
|
|
||||||
func (s *spotify) enabled() bool {
|
|
||||||
return false
|
|
||||||
}
|
|
33
src/segment_spotify_wsl.go
Normal file
33
src/segment_spotify_wsl.go
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
//go:build !darwin && !windows
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/csv"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
func (s *spotify) enabled() bool {
|
||||||
|
if !s.env.isWsl() {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
tlist, err := s.env.runCommand("tasklist.exe", "/V", "/FI", "Imagename eq Spotify.exe", "/FO", "CSV", "/NH")
|
||||||
|
if err != nil || strings.HasPrefix(tlist, "INFO") {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
records, err := csv.NewReader(strings.NewReader(tlist)).ReadAll()
|
||||||
|
if err != nil || len(records) == 0 {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
for _, record := range records {
|
||||||
|
title := record[len(record)-1]
|
||||||
|
if strings.Contains(title, " - ") {
|
||||||
|
infos := strings.Split(title, " - ")
|
||||||
|
s.artist = infos[0]
|
||||||
|
s.track = strings.Join(infos[1:], " - ")
|
||||||
|
s.status = "playing"
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
65
src/segment_spotify_wsl_test.go
Normal file
65
src/segment_spotify_wsl_test.go
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
//go:build !darwin && !windows
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestSpotifyWsl(t *testing.T) {
|
||||||
|
cases := []struct {
|
||||||
|
Case string
|
||||||
|
ExpectedString string
|
||||||
|
ExpectedEnabled bool
|
||||||
|
ExecOutput string
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
Case: "Spotify not running",
|
||||||
|
ExpectedString: " - ",
|
||||||
|
ExpectedEnabled: false,
|
||||||
|
ExecOutput: "INFO: No tasks are running which match the specified criteria.\n",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Case: "Spotify stopped/paused",
|
||||||
|
ExpectedString: " - ",
|
||||||
|
ExpectedEnabled: false,
|
||||||
|
ExecOutput: `"Spotify.exe","21824","Console","1","124,928 K","Running","PC\user","0:09:44","Spotify Premium"
|
||||||
|
"Spotify.exe","21876","Console","1","25,520 K","Running","PC\user","0:00:00","N/A"
|
||||||
|
"Spotify.exe","21988","Console","1","60,840 K","Not Responding","PC\user","0:04:56","AngleHiddenWindow"
|
||||||
|
"Spotify.exe","22052","Console","1","29,040 K","Unknown","PC\user","0:00:00","N/A"
|
||||||
|
"Spotify.exe","22072","Console","1","43,960 K","Unknown","PC\user","0:01:50","N/A"
|
||||||
|
"Spotify.exe","10404","Console","1","256,924 K","Unknown","PC\user","0:10:49","N/A"`,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Case: "Spotify playing",
|
||||||
|
ExpectedString: "\ue602 Candlemass - Spellbreaker",
|
||||||
|
ExpectedEnabled: true,
|
||||||
|
ExecOutput: `"Spotify.exe","21824","Console","1","124,928 K","Running","PC\user","0:09:44","Candlemass - Spellbreaker"
|
||||||
|
"Spotify.exe","21876","Console","1","25,520 K","Running","PC\user","0:00:00","N/A"
|
||||||
|
"Spotify.exe","21988","Console","1","60,840 K","Not Responding","PC\user","0:04:56","AngleHiddenWindow"
|
||||||
|
"Spotify.exe","22052","Console","1","29,040 K","Unknown","PC\user","0:00:00","N/A"
|
||||||
|
"Spotify.exe","22072","Console","1","43,960 K","Unknown","PC\user","0:01:50","N/A"
|
||||||
|
"Spotify.exe","10404","Console","1","256,924 K","Unknown","PC\user","0:10:49","N/A"`,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Case: "tasklist.exe not in path",
|
||||||
|
ExpectedString: " - ",
|
||||||
|
ExpectedEnabled: false,
|
||||||
|
ExecOutput: ""},
|
||||||
|
}
|
||||||
|
for _, tc := range cases {
|
||||||
|
env := new(MockedEnvironment)
|
||||||
|
env.On("isWsl", nil).Return(true)
|
||||||
|
env.On("runCommand", "tasklist.exe", []string{"/V", "/FI", "Imagename eq Spotify.exe", "/FO", "CSV", "/NH"}).Return(tc.ExecOutput, nil)
|
||||||
|
props := &properties{}
|
||||||
|
s := &spotify{
|
||||||
|
env: env,
|
||||||
|
props: props,
|
||||||
|
}
|
||||||
|
assert.Equal(t, tc.ExpectedEnabled, s.enabled(), fmt.Sprintf("Failed in case: %s", tc.Case))
|
||||||
|
assert.Equal(t, tc.ExpectedString, s.string(), fmt.Sprintf("Failed in case: %s", tc.Case))
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue