Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
#131 Use a ServiceMessageHandler interface instead of manually parsi…
…ng TeamCity Service Messages and avoid storing corresponding text lines in memory
- Loading branch information
NikolayPianikov
authored and
NikolayPianikov
committed
Jun 29, 2018
1 parent
74cd78f
commit 18abac4
Showing
34 changed files
with
1,184 additions
and
188 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,5 @@ | ||
plugins { | ||
id "org.jetbrains.kotlin.jvm" version "1.1.51" | ||
id "org.jetbrains.kotlin.jvm" version "1.2.50" | ||
} | ||
|
||
ext { | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
6 changes: 6 additions & 0 deletions
6
...n-dotnet-agent/src/main/kotlin/jetbrains/buildServer/agent/runner/ServiceMessageSource.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
package jetbrains.buildServer.agent.runner | ||
|
||
import jetbrains.buildServer.messages.serviceMessages.ServiceMessage | ||
import jetbrains.buildServer.rx.Observable | ||
|
||
interface ServiceMessageSource: Observable<ServiceMessage> { } |
34 changes: 34 additions & 0 deletions
34
...tnet-agent/src/main/kotlin/jetbrains/buildServer/agent/runner/ServiceMessageSourceImpl.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
package jetbrains.buildServer.agent.runner | ||
|
||
import jetbrains.buildServer.messages.serviceMessages.ServiceMessage | ||
import jetbrains.buildServer.messages.serviceMessages.ServiceMessageHandler | ||
import jetbrains.buildServer.messages.serviceMessages.ServiceMessageTypes | ||
import jetbrains.buildServer.messages.serviceMessages.ServiceMessagesRegister | ||
import jetbrains.buildServer.rx.* | ||
|
||
class ServiceMessageSourceImpl( | ||
private val _serviceMessagesRegister: ServiceMessagesRegister) | ||
: ServiceMessageSource, ServiceMessageHandler { | ||
private val _subject: Subject<ServiceMessage> = subjectOf() | ||
private val _sharedSource: Observable<ServiceMessage> = _subject | ||
.track( | ||
{ if(it) activate() }, | ||
{ if(!it) deactivate() }) | ||
.share() | ||
|
||
override fun subscribe(observer: Observer<ServiceMessage>): Disposable = | ||
_sharedSource.subscribe(observer) | ||
|
||
override fun handle(serviceMessage: ServiceMessage) = | ||
_subject.onNext(serviceMessage) | ||
|
||
private fun activate() = | ||
_serviceMessages.forEach { _serviceMessagesRegister.registerHandler(it, this) } | ||
|
||
private fun deactivate() = | ||
_serviceMessages.forEach { _serviceMessagesRegister.removeHandler(it) } | ||
|
||
companion object { | ||
private val _serviceMessages = sequenceOf(ServiceMessageTypes.TEST_FAILED) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
7 changes: 0 additions & 7 deletions
7
...n-dotnet-agent/src/main/kotlin/jetbrains/buildServer/agent/runner/WorkflowOutputFilter.kt
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
7 changes: 0 additions & 7 deletions
7
plugin-dotnet-agent/src/main/kotlin/jetbrains/buildServer/dotnet/FailedTestDetector.kt
This file was deleted.
Oops, something went wrong.
6 changes: 6 additions & 0 deletions
6
plugin-dotnet-agent/src/main/kotlin/jetbrains/buildServer/dotnet/FailedTestSource.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
package jetbrains.buildServer.dotnet | ||
|
||
import jetbrains.buildServer.rx.Observable | ||
|
||
interface FailedTestSource: Observable<Unit> { | ||
} |
16 changes: 16 additions & 0 deletions
16
plugin-dotnet-agent/src/main/kotlin/jetbrains/buildServer/dotnet/FailedTestSourceImpl.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
package jetbrains.buildServer.dotnet | ||
|
||
import jetbrains.buildServer.agent.runner.ServiceMessageSource | ||
import jetbrains.buildServer.messages.serviceMessages.ServiceMessageTypes | ||
import jetbrains.buildServer.rx.* | ||
|
||
class FailedTestSourceImpl( | ||
private val _serviceMessageSource: ServiceMessageSource) | ||
: FailedTestSource { | ||
override fun subscribe(observer: Observer<Unit>): Disposable = | ||
_serviceMessageSource | ||
.filter { ServiceMessageTypes.TEST_FAILED.equals(it.messageName, true) } | ||
.first() | ||
.map { Unit } | ||
.subscribe(observer) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.