Skip to content

Instantly share code, notes, and snippets.

View gjesse's full-sized avatar
🤘
message not available

Jesse Hodges gjesse

🤘
message not available
View GitHub Profile
@gjesse
gjesse / test-results.txt
Created April 20, 2015 18:52
ThrottleLast + window overlapping behavior
[0]
[0, 1, 2]
[2, 3]
[3, 4]
[4, 5]
[5, 6, 7]
[7, 8, 9]
[10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99]
@Test
public void testWindowClosingQuickly() {
Observable<Integer> event = Observable.just(1, 2);
Observable<Integer> closing = event.share().throttleLast(30, TimeUnit.MILLISECONDS);
List<Integer> events = event
.window(closing).flatMap(window -> window.toList()).toBlocking().first();
@gjesse
gjesse / downtime.java
Last active August 29, 2015 14:22
using RxJava to implement downtime alarms
/**
* as long as new Observations are added to _lastSeen, we
* will emit CLEARED events. If interval passes without any
* observation, a stream of BREACH events will be emitted
* until such time we see more data incoming
**/
PublishSubject<Observation> lastSeen = PublishSubject.create();
// dump incoming events in to _lastSeen.onNext()
@gjesse
gjesse / TestPredicateWindow.java
Created November 21, 2015 15:46
example of using distinctUntilChanged and window to segment an ordered observable into discrete buckets.
package net.loshodges;
import com.google.common.collect.Lists;
import org.junit.Test;
import rx.Observable;
import rx.observers.TestSubscriber;
import rx.schedulers.Schedulers;
import java.util.List;
import java.util.concurrent.CountDownLatch;
package com.boundary.sargon.rx.operators;
import rx.Observable;
import rx.Subscriber;
import rx.functions.Func1;
import rx.internal.operators.BufferUntilSubscriber;
import rx.subscriptions.Subscriptions;
import java.util.Objects;
@Test
public void testReduce() {
Observable<Integer> one = Observable.just(1);
Observable<Integer> two = Observable.just(1,1);
Observable<Integer> empty = Observable.empty();
System.out.println(reduce(one));
System.out.println(reduce(two));
System.out.println(reduce(empty));
fun <T> T?.requireNonNull(id: String): T = this ?: throw NullPointerException("%s must be specified".format(id))
# drop traffic to zk from a specific user:
sudo iptables -A OUTPUT -p tcp --destination-port 2181 -m owner --uid-owner sargon-zero -j DROP
# restore
sudo iptables -D OUTPUT -p tcp --destination-port 2181 -m owner --uid-owner sargon-zero -j DROP
/**
* Gauge-based health check that will return unhealthy if the
* gauge value falls below the threshold
*/
public class RatioGaugeHealthCheck extends HealthCheck {
private final RatioGauge gauge;
private final double threshold;
private final String name;
@gjesse
gjesse / nginx-cors.conf
Created February 6, 2017 23:42 — forked from algal/nginx-cors.conf
nginx configuration for CORS (Cross-Origin Resource Sharing), with an origin whitelist, and HTTP Basic Access authentication allowed
#
# A CORS (Cross-Origin Resouce Sharing) config for nginx
#
# == Purpose
#
# This nginx configuration enables CORS requests in the following way:
# - enables CORS just for origins on a whitelist specified by a regular expression
# - CORS preflight request (OPTIONS) are responded immediately
# - Access-Control-Allow-Credentials=true for GET and POST requests