Added pin config builder. Closes #10
This commit is contained in:
parent
045ad0f276
commit
fc77b73399
7 changed files with 225 additions and 31 deletions
38
README.md
38
README.md
|
@ -1,10 +1,13 @@
|
||||||
# [Pinboard](https://pinboard.in) Poster for Kotlin/Java
|
# [Pinboard](https://pinboard.in) Poster for Kotlin, Java and Android
|
||||||
|
|
||||||
[](https://opensource.org/licenses/BSD-3-Clause) [](https://github.com/ethauvin/pinboard-poster/releases/latest) [](https://search.maven.org/search?q=g:%22net.thauvin.erik%22%20AND%20a:%22pinboard-poster%22)
|
[](https://opensource.org/licenses/BSD-3-Clause) [](https://github.com/ethauvin/pinboard-poster/releases/latest)
|
||||||
|
[](https://central.sonatype.com/artifact/net.thauvin.erik/pinboard-poster)
|
||||||
|
|
||||||
[](https://sonarcloud.io/dashboard?id=ethauvin_pinboard-poster) [](https://github.com/ethauvin/pinboard-poster/actions/workflows/gradle.yml) [](https://circleci.com/gh/ethauvin/pinboard-poster/tree/master)
|
[](https://sonarcloud.io/dashboard?id=ethauvin_pinboard-poster)
|
||||||
|
[](https://github.com/ethauvin/pinboard-poster/actions/workflows/gradle.yml)
|
||||||
|
[](https://circleci.com/gh/ethauvin/pinboard-poster/tree/master)
|
||||||
|
|
||||||
A small Kotlin/Java/Android library for posting to [Pinboard](https://pinboard.in).
|
A small library for posting to [Pinboard](https://pinboard.in).
|
||||||
|
|
||||||
## Examples
|
## Examples
|
||||||
|
|
||||||
|
@ -15,19 +18,28 @@ A small Kotlin/Java/Android library for posting to [Pinboard](https://pinboard.i
|
||||||
val poster = PinboardPoster("user:TOKEN")
|
val poster = PinboardPoster("user:TOKEN")
|
||||||
|
|
||||||
poster.addPin("https://www.example.com/foo", "This is a test")
|
poster.addPin("https://www.example.com/foo", "This is a test")
|
||||||
|
poster.addPin("https://examples.com", "This is a test", tags = arrayOf("foo", "bar"))
|
||||||
poster.deletePin("https:///www.example.com/bar")
|
poster.deletePin("https:///www.example.com/bar")
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
[View Example](https://github.com/ethauvin/pinboard-poster/blob/master/samples/kotlin/src/main/kotlin/net/thauvin/erik/pinboard/samples/KotlinExample.kt)
|
[View Example](https://github.com/ethauvin/pinboard-poster/blob/master/samples/kotlin/src/main/kotlin/net/thauvin/erik/pinboard/samples/KotlinExample.kt)
|
||||||
|
|
||||||
### Java
|
### Java
|
||||||
|
|
||||||
```java
|
```java
|
||||||
|
|
||||||
final PinboardPoster poster = new PinBboardPoster("user:TOKEN");
|
final PinboardPoster poster = new PinBboardPoster("user:TOKEN");
|
||||||
|
|
||||||
poster.addPin("https://www.example.com/foo", "This is a test");
|
poster.addPin("https://www.example.com/foo", "This is a test");
|
||||||
|
poster.addPin(new AddConfig.Builder()
|
||||||
|
.url("https://example.com")
|
||||||
|
.description("This is a test")
|
||||||
|
.tags("foo", "bar")
|
||||||
|
.build());
|
||||||
poster.deletePin("https:///www.example.com/bar");
|
poster.deletePin("https:///www.example.com/bar");
|
||||||
```
|
```
|
||||||
|
|
||||||
[View Example](https://github.com/ethauvin/pinboard-poster/blob/master/samples/java/src/main/java/net/thauvin/erik/pinboard/samples/JavaExample.java)
|
[View Example](https://github.com/ethauvin/pinboard-poster/blob/master/samples/java/src/main/java/net/thauvin/erik/pinboard/samples/JavaExample.java)
|
||||||
|
|
||||||
Your API authentication token is available on the [Pinboard settings page](https://pinboard.in/settings/password).
|
Your API authentication token is available on the [Pinboard settings page](https://pinboard.in/settings/password).
|
||||||
|
@ -45,24 +57,29 @@ dependencies {
|
||||||
compile 'net.thauvin.erik:pinboard-poster:1.0.4'
|
compile 'net.thauvin.erik:pinboard-poster:1.0.4'
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
[View Example](https://github.com/ethauvin/pinboard-poster/blob/master/samples/java/build.gradle)
|
[View Example](https://github.com/ethauvin/pinboard-poster/blob/master/samples/java/build.gradle)
|
||||||
[View Kotlin DSL Example](https://github.com/ethauvin/pinboard-poster/blob/master/samples/kotlin/build.gradle.kts)
|
[View Kotlin DSL Example](https://github.com/ethauvin/pinboard-poster/blob/master/samples/kotlin/build.gradle.kts)
|
||||||
|
|
||||||
Instructions for using with Maven, Ivy, etc. can be found on [Maven Central](https://search.maven.org/artifact/net.thauvin.erik/pinboard-poster/1.0.4/jar).
|
Instructions for using with Maven, Ivy, etc. can be found on [Maven Central](https://central.sonatype.com/artifact/net.thauvin.erik/pinboard-poster).
|
||||||
|
|
||||||
## Adding
|
## Adding
|
||||||
|
|
||||||
The `addPin` function support all of the [Pinboard API parameters](https://pinboard.in/api/#posts_add):
|
The `addPin` function support all of the [Pinboard API parameters](https://pinboard.in/api/#posts_add):
|
||||||
|
|
||||||
```kotlin
|
```kotlin
|
||||||
poster.addPin(url = "https://www.example.com",
|
import java.time.ZonedDateTime
|
||||||
|
|
||||||
|
poster.addPin(
|
||||||
|
url = "https://www.example.com",
|
||||||
description = "This is the title",
|
description = "This is the title",
|
||||||
extended = "This is the extended description.",
|
extended = "This is the extended description.",
|
||||||
tags = "tag1 tag2 tag3",
|
tags = arrayOf("tag1", "tag2", "tag3"),
|
||||||
dt = "2010-12-11T19:48:02Z",
|
dt = ZonedDateTime.now(),
|
||||||
replace = true,
|
replace = true,
|
||||||
shared = true,
|
shared = true,
|
||||||
toRead = false)
|
toRead = false
|
||||||
|
)
|
||||||
```
|
```
|
||||||
|
|
||||||
`url` and `description` are required.
|
`url` and `description` are required.
|
||||||
|
@ -84,13 +101,16 @@ It returns `true` if the bookmark was deleted successfully, `false` otherwise.
|
||||||
The library used [`java.util.logging`](https://docs.oracle.com/javase/8/docs/api/java/util/logging/package-summary.html) to log errors. Logging can be configured as follows:
|
The library used [`java.util.logging`](https://docs.oracle.com/javase/8/docs/api/java/util/logging/package-summary.html) to log errors. Logging can be configured as follows:
|
||||||
|
|
||||||
#### Kotlin
|
#### Kotlin
|
||||||
|
|
||||||
```kotlin
|
```kotlin
|
||||||
with(poster.logger) {
|
with(poster.logger) {
|
||||||
addHandler(ConsoleHandler().apply { level = Level.FINE })
|
addHandler(ConsoleHandler().apply { level = Level.FINE })
|
||||||
level = Level.FINE
|
level = Level.FINE
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Java
|
#### Java
|
||||||
|
|
||||||
```java
|
```java
|
||||||
final ConsoleHandler consoleHandler = new ConsoleHandler();
|
final ConsoleHandler consoleHandler = new ConsoleHandler();
|
||||||
consoleHandler.setLevel(Level.FINE);
|
consoleHandler.setLevel(Level.FINE);
|
||||||
|
|
|
@ -2,8 +2,11 @@
|
||||||
<SmellBaseline>
|
<SmellBaseline>
|
||||||
<ManuallySuppressedIssues/>
|
<ManuallySuppressedIssues/>
|
||||||
<CurrentIssues>
|
<CurrentIssues>
|
||||||
<ID>LongParameterList:PinboardPoster.kt$PinboardPoster$( url: String, description: String, extended: String = "", tags: String = "", dt: String = "", replace: Boolean = true, shared: Boolean = true, toRead: Boolean = false )</ID>
|
<ID>LongParameterList:PinConfig.kt$PinConfig$( val url: String, val description: String, val extended: String, val tags: Array<out String>, val dt: ZonedDateTime, val replace: Boolean, val shared: Boolean, val toRead: Boolean )</ID>
|
||||||
|
<ID>LongParameterList:PinboardPoster.kt$PinboardPoster$( url: String, description: String, extended: String = "", vararg tags: String = emptyArray(), dt: ZonedDateTime = ZonedDateTime.now(), replace: Boolean = true, shared: Boolean = true, toRead: Boolean = false )</ID>
|
||||||
<ID>NestedBlockDepth:PinboardPoster.kt$PinboardPoster$private fun executeMethod(method: String, params: Map<String, String>): Boolean</ID>
|
<ID>NestedBlockDepth:PinboardPoster.kt$PinboardPoster$private fun executeMethod(method: String, params: Map<String, String>): Boolean</ID>
|
||||||
<ID>ThrowsCount:PinboardPoster.kt$PinboardPoster$@Throws(IOException::class) internal fun parseMethodResponse(method: String, response: String)</ID>
|
<ID>ThrowsCount:PinboardPoster.kt$PinboardPoster$@Throws(IOException::class) internal fun parseMethodResponse(method: String, response: String)</ID>
|
||||||
|
<ID>TooManyFunctions:PinConfig.kt$PinConfig$Builder</ID>
|
||||||
|
<ID>WildcardImport:PinboardPosterTest.kt$import org.testng.Assert.*</ID>
|
||||||
</CurrentIssues>
|
</CurrentIssues>
|
||||||
</SmellBaseline>
|
</SmellBaseline>
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
*/
|
*/
|
||||||
package net.thauvin.erik.pinboard.samples;
|
package net.thauvin.erik.pinboard.samples;
|
||||||
|
|
||||||
|
import net.thauvin.erik.pinboard.PinConfig;
|
||||||
import net.thauvin.erik.pinboard.PinboardPoster;
|
import net.thauvin.erik.pinboard.PinboardPoster;
|
||||||
|
|
||||||
import java.nio.file.Paths;
|
import java.nio.file.Paths;
|
||||||
|
@ -40,7 +41,7 @@ import java.util.logging.Logger;
|
||||||
|
|
||||||
public class JavaExample {
|
public class JavaExample {
|
||||||
public static void main(String[] args) {
|
public static void main(String[] args) {
|
||||||
final String url = "http://www.example.com/pinboard";
|
final String url = "httpz://example.com/pinboard";
|
||||||
final PinboardPoster poster;
|
final PinboardPoster poster;
|
||||||
|
|
||||||
if (args.length == 1) {
|
if (args.length == 1) {
|
||||||
|
@ -59,7 +60,12 @@ public class JavaExample {
|
||||||
logger.setLevel(Level.FINE);
|
logger.setLevel(Level.FINE);
|
||||||
|
|
||||||
// Add Pin
|
// Add Pin
|
||||||
if (poster.addPin(url, "Testing", "Extended test", "test java")) {
|
if (poster.addPin(new PinConfig.Builder()
|
||||||
|
.url(url)
|
||||||
|
.description("Testing")
|
||||||
|
.extended("Extra")
|
||||||
|
.tags("test", "java")
|
||||||
|
.build())) {
|
||||||
System.out.println("Added: " + url);
|
System.out.println("Added: " + url);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -37,7 +37,7 @@ import java.util.logging.ConsoleHandler
|
||||||
import java.util.logging.Level
|
import java.util.logging.Level
|
||||||
|
|
||||||
fun main(args: Array<String>) {
|
fun main(args: Array<String>) {
|
||||||
val url = "http://www.example.com/pinboard"
|
val url = "httpz://example.com/pinboard"
|
||||||
|
|
||||||
val poster = if (args.size == 1) {
|
val poster = if (args.size == 1) {
|
||||||
// API Token is an argument
|
// API Token is an argument
|
||||||
|
@ -54,7 +54,7 @@ fun main(args: Array<String>) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add Pin
|
// Add Pin
|
||||||
if (poster.addPin(url, "Testing", "Extended test", "test kotlin")) {
|
if (poster.addPin(url, "Testing", "Extended test", tags = arrayOf("test", "kotlin"))) {
|
||||||
println("Added: $url")
|
println("Added: $url")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
112
src/main/kotlin/net/thauvin/erik/pinboard/PinConfig.kt
Normal file
112
src/main/kotlin/net/thauvin/erik/pinboard/PinConfig.kt
Normal file
|
@ -0,0 +1,112 @@
|
||||||
|
/*
|
||||||
|
* PinConfig.kt
|
||||||
|
*
|
||||||
|
* Copyright (c) 2017-2023, Erik C. Thauvin (erik@thauvin.net)
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* Redistributions of source code must retain the above copyright notice, this
|
||||||
|
* list of conditions and the following disclaimer.
|
||||||
|
*
|
||||||
|
* Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* Neither the name of this project nor the names of its contributors may be
|
||||||
|
* used to endorse or promote products derived from this software without
|
||||||
|
* specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||||
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
||||||
|
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||||
|
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
package net.thauvin.erik.pinboard
|
||||||
|
|
||||||
|
import java.time.ZonedDateTime
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provides a builder to add a pin.
|
||||||
|
*/
|
||||||
|
class PinConfig private constructor(
|
||||||
|
val url: String,
|
||||||
|
val description: String,
|
||||||
|
val extended: String,
|
||||||
|
val tags: Array<out String>,
|
||||||
|
val dt: ZonedDateTime,
|
||||||
|
val replace: Boolean,
|
||||||
|
val shared: Boolean,
|
||||||
|
val toRead: Boolean
|
||||||
|
) {
|
||||||
|
/**
|
||||||
|
* Configures the parameters to add a pin.
|
||||||
|
*/
|
||||||
|
data class Builder(
|
||||||
|
private var url: String = "",
|
||||||
|
private var description: String = "",
|
||||||
|
private var extended: String = "",
|
||||||
|
private var tags: Array<out String> = emptyArray(),
|
||||||
|
private var dt: ZonedDateTime = ZonedDateTime.now(),
|
||||||
|
private var replace: Boolean = true,
|
||||||
|
private var shared: Boolean = true,
|
||||||
|
private var toRead: Boolean = false
|
||||||
|
) {
|
||||||
|
fun url(url: String) = apply { this.url = url }
|
||||||
|
fun description(description: String) = apply { this.description = description }
|
||||||
|
fun extended(extended: String) = apply { this.extended = extended }
|
||||||
|
fun tags(vararg tag: String) = apply { this.tags = tag }
|
||||||
|
fun dt(datetime: ZonedDateTime) = apply { this.dt = datetime }
|
||||||
|
fun replace(replace: Boolean) = apply { this.replace = replace }
|
||||||
|
fun shared(shared: Boolean) = apply { this.shared = shared }
|
||||||
|
fun toRead(toRead: Boolean) = apply { this.toRead = toRead }
|
||||||
|
|
||||||
|
fun build() = PinConfig(
|
||||||
|
url,
|
||||||
|
description,
|
||||||
|
extended,
|
||||||
|
tags,
|
||||||
|
dt,
|
||||||
|
replace,
|
||||||
|
shared,
|
||||||
|
toRead
|
||||||
|
)
|
||||||
|
|
||||||
|
override fun equals(other: Any?): Boolean {
|
||||||
|
if (this === other) return true
|
||||||
|
if (javaClass != other?.javaClass) return false
|
||||||
|
|
||||||
|
other as Builder
|
||||||
|
|
||||||
|
if (url != other.url) return false
|
||||||
|
if (description != other.description) return false
|
||||||
|
if (extended != other.extended) return false
|
||||||
|
if (!tags.contentEquals(other.tags)) return false
|
||||||
|
if (dt != other.dt) return false
|
||||||
|
if (replace != other.replace) return false
|
||||||
|
if (shared != other.shared) return false
|
||||||
|
if (toRead != other.toRead) return false
|
||||||
|
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun hashCode(): Int {
|
||||||
|
var result = url.hashCode()
|
||||||
|
result = 31 * result + description.hashCode()
|
||||||
|
result = 31 * result + extended.hashCode()
|
||||||
|
result = 31 * result + tags.contentHashCode()
|
||||||
|
result = 31 * result + dt.hashCode()
|
||||||
|
result = 31 * result + replace.hashCode()
|
||||||
|
result = 31 * result + shared.hashCode()
|
||||||
|
result = 31 * result + toRead.hashCode()
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
/*
|
/*
|
||||||
* PinboardPoster.kt
|
* PinboardPoster.kt
|
||||||
*
|
*
|
||||||
* Copyright (c) 2017-2022, Erik C. Thauvin (erik@thauvin.net)
|
* Copyright (c) 2017-2023, Erik C. Thauvin (erik@thauvin.net)
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -44,6 +44,8 @@ import java.net.MalformedURLException
|
||||||
import java.net.URL
|
import java.net.URL
|
||||||
import java.nio.file.Files
|
import java.nio.file.Files
|
||||||
import java.nio.file.Path
|
import java.nio.file.Path
|
||||||
|
import java.time.ZonedDateTime
|
||||||
|
import java.time.format.DateTimeFormatter
|
||||||
import java.util.*
|
import java.util.*
|
||||||
import java.util.logging.Level
|
import java.util.logging.Level
|
||||||
import java.util.logging.Logger
|
import java.util.logging.Logger
|
||||||
|
@ -132,6 +134,24 @@ open class PinboardPoster() {
|
||||||
}.build()
|
}.build()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds a bookmark to Pinboard
|
||||||
|
*
|
||||||
|
* This method supports of all the [Pinboard API Parameters](https://pinboard.in/api/#posts_add).
|
||||||
|
*/
|
||||||
|
fun addPin(config: PinConfig): Boolean {
|
||||||
|
return addPin(
|
||||||
|
url = config.url,
|
||||||
|
description = config.description,
|
||||||
|
extended = config.extended,
|
||||||
|
tags = config.tags,
|
||||||
|
dt = config.dt,
|
||||||
|
replace = config.replace,
|
||||||
|
shared = config.shared,
|
||||||
|
toRead = config.toRead
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a bookmark to Pinboard.
|
* Adds a bookmark to Pinboard.
|
||||||
*
|
*
|
||||||
|
@ -153,8 +173,8 @@ open class PinboardPoster() {
|
||||||
url: String,
|
url: String,
|
||||||
description: String,
|
description: String,
|
||||||
extended: String = "",
|
extended: String = "",
|
||||||
tags: String = "",
|
vararg tags: String = emptyArray(),
|
||||||
dt: String = "",
|
dt: ZonedDateTime = ZonedDateTime.now(),
|
||||||
replace: Boolean = true,
|
replace: Boolean = true,
|
||||||
shared: Boolean = true,
|
shared: Boolean = true,
|
||||||
toRead: Boolean = false
|
toRead: Boolean = false
|
||||||
|
@ -169,8 +189,8 @@ open class PinboardPoster() {
|
||||||
"url" to url,
|
"url" to url,
|
||||||
"description" to description,
|
"description" to description,
|
||||||
"extended" to extended,
|
"extended" to extended,
|
||||||
"tags" to tags,
|
"tags" to tags.joinToString(","),
|
||||||
"dt" to dt,
|
"dt" to DateTimeFormatter.ISO_INSTANT.format(dt.withNano(0)),
|
||||||
"replace" to yesNo(replace),
|
"replace" to yesNo(replace),
|
||||||
"shared" to yesNo(shared),
|
"shared" to yesNo(shared),
|
||||||
"toread" to yesNo(toRead)
|
"toread" to yesNo(toRead)
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/*
|
/*
|
||||||
* PinboardPosterTest.kt
|
* PinboardPosterTest.kt
|
||||||
*
|
*
|
||||||
* Copyright (c) 2017-2022, Erik C. Thauvin (erik@thauvin.net)
|
* Copyright (c) 2017-2023, Erik C. Thauvin (erik@thauvin.net)
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
@ -32,20 +32,20 @@
|
||||||
|
|
||||||
package net.thauvin.erik.pinboard
|
package net.thauvin.erik.pinboard
|
||||||
|
|
||||||
import org.testng.Assert.assertFalse
|
import org.testng.Assert.*
|
||||||
import org.testng.Assert.assertTrue
|
|
||||||
import org.testng.Assert.expectThrows
|
|
||||||
import org.testng.annotations.Test
|
import org.testng.annotations.Test
|
||||||
import java.io.IOException
|
import java.io.IOException
|
||||||
import java.nio.file.Files
|
import java.nio.file.Files
|
||||||
import java.nio.file.Paths
|
import java.nio.file.Paths
|
||||||
import java.util.Properties
|
import java.time.ZonedDateTime
|
||||||
|
import java.util.*
|
||||||
import java.util.logging.Level
|
import java.util.logging.Level
|
||||||
|
|
||||||
class PinboardPosterTest {
|
class PinboardPosterTest {
|
||||||
private val url = "http://www.example.com/?random=" + (1000..10000).random()
|
private val url = "http://www.example.com/?random=" + (1000..10000).random()
|
||||||
private val desc = "This is a test."
|
private val desc = "This is a test."
|
||||||
private val localProps = Paths.get("local.properties")
|
private val localProps = Paths.get("local.properties")
|
||||||
|
private val isCi = "true" == System.getenv("CI")
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun testAddPin() {
|
fun testAddPin() {
|
||||||
|
@ -61,10 +61,42 @@ class PinboardPosterTest {
|
||||||
// assertFalse(poster.addPin(url, desc), "apiToken: ${poster.apiToken}")
|
// assertFalse(poster.addPin(url, desc), "apiToken: ${poster.apiToken}")
|
||||||
|
|
||||||
poster = PinboardPoster(localProps)
|
poster = PinboardPoster(localProps)
|
||||||
|
if (!isCi) {
|
||||||
poster.logger.level = Level.FINE
|
poster.logger.level = Level.FINE
|
||||||
|
}
|
||||||
assertTrue(poster.addPin(url, desc), "apiToken: ${Constants.ENV_API_TOKEN}")
|
assertTrue(poster.addPin(url, desc), "apiToken: ${Constants.ENV_API_TOKEN}")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun testAddPinConfig() {
|
||||||
|
val poster = PinboardPoster(localProps)
|
||||||
|
if (!isCi) {
|
||||||
|
poster.logger.level = Level.FINE
|
||||||
|
}
|
||||||
|
|
||||||
|
var config = PinConfig.Builder().url(url).description(desc).extended("extra")
|
||||||
|
|
||||||
|
assertTrue(poster.addPin(config.build()), "apiToken: ${Constants.ENV_API_TOKEN}")
|
||||||
|
|
||||||
|
config = config.tags("foo", "bar")
|
||||||
|
assertTrue(poster.addPin(config.build()), "tags(foo,bar)")
|
||||||
|
|
||||||
|
config = config.shared(false)
|
||||||
|
assertTrue(poster.addPin(config.build()), "shared(false)")
|
||||||
|
|
||||||
|
try {
|
||||||
|
assertFalse(poster.addPin(config.replace(false).build()))
|
||||||
|
} catch (e: IOException) {
|
||||||
|
assertTrue(e.message!!.contains("item already exists"))
|
||||||
|
}
|
||||||
|
|
||||||
|
config = config.replace(true).toRead(true)
|
||||||
|
assertTrue(poster.addPin(config.build()), "toRead(true)")
|
||||||
|
|
||||||
|
config = config.dt(ZonedDateTime.now())
|
||||||
|
assertTrue(poster.addPin(config.build()), "dt(now)")
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun testDeletePin() {
|
fun testDeletePin() {
|
||||||
val props = if (Files.exists(localProps)) {
|
val props = if (Files.exists(localProps)) {
|
||||||
|
@ -84,8 +116,9 @@ class PinboardPosterTest {
|
||||||
assertFalse(poster.deletePin(url), "apiEndPoint: <blank>")
|
assertFalse(poster.deletePin(url), "apiEndPoint: <blank>")
|
||||||
|
|
||||||
poster = PinboardPoster(localProps, Constants.ENV_API_TOKEN)
|
poster = PinboardPoster(localProps, Constants.ENV_API_TOKEN)
|
||||||
|
if (!isCi) {
|
||||||
poster.logger.level = Level.FINE
|
poster.logger.level = Level.FINE
|
||||||
|
}
|
||||||
poster.apiEndPoint = Constants.API_ENDPOINT
|
poster.apiEndPoint = Constants.API_ENDPOINT
|
||||||
assertTrue(poster.deletePin(url), "apiEndPoint: ${Constants.API_ENDPOINT}")
|
assertTrue(poster.deletePin(url), "apiEndPoint: ${Constants.API_ENDPOINT}")
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue