Skip to content

Commit

Permalink
Merge branch 'rlamb/common-persistent-store' into cw/sc-217924/persis…
Browse files Browse the repository at this point in the history
…tent-store-refactoring
  • Loading branch information
cwaldren-ld committed Nov 16, 2023
2 parents 2475f7b + f2856a9 commit 1676f67
Show file tree
Hide file tree
Showing 9 changed files with 231 additions and 48 deletions.
2 changes: 1 addition & 1 deletion .github/actions/install-boost/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ runs:
shell: bash
run: |
brew install boost
echo "BOOST_ROOT=$(boost --prefix boost@1.82)" >> $GITHUB_OUTPUT
echo "BOOST_ROOT=$(brew --prefix boost)" >> $GITHUB_OUTPUT
- name: Determine root
id: determine-root
Expand Down
32 changes: 28 additions & 4 deletions .github/actions/install-openssl/action.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
name: Install OpenSSL
description: 'Install OpenSSL >= 3 if not already present.'

outputs:
OPENSSL_ROOT_DIR:
description: The location of the installed OpenSSL.
value: ${{ steps.determine-root.outputs.OPENSSL_ROOT_DIR }}
runs:
using: composite
steps:
Expand All @@ -13,20 +17,40 @@ runs:
# The Mac runner already has OpenSSL > 3 via brew, but we need to expose its
# install path to CMake.
- name: Install for Mac
id: brew-action
if: runner.os == 'macOS'
shell: bash
run: echo "OPENSSL_ROOT_DIR=$(brew --prefix openssl@3)" >> "$GITHUB_ENV"
run: |
echo "OpenSSL Prefix: $(brew --prefix openssl@3)"
echo "OPENSSL_ROOT_DIR=$(brew --prefix openssl@3)" >> $GITHUB_OUTPUT
# The Windows runner has an older version of OpenSSL and needs to be upgraded.
# Additionally it seems to randomly be installed in OpenSSL-Win64 or OpenSSL depending on
# Additionally, it seems to randomly be installed in OpenSSL-Win64 or OpenSSL depending on
# the runner Github gives us.
- name: Install for Windows
id: choco-action
if: runner.os == 'Windows'
shell: bash
run: |
choco upgrade openssl --no-progress
if [ -d "C:\Program Files\OpenSSL-Win64" ]; then
echo "OPENSSL_ROOT_DIR=C:\Program Files\OpenSSL-Win64" >> "$GITHUB_ENV"
echo "OPENSSL_ROOT_DIR=C:\Program Files\OpenSSL-Win64" >> $GITHUB_OUTPUT
else
echo "OPENSSL_ROOT_DIR=C:\Program Files\OpenSSL" >> "$GITHUB_ENV"
echo "OPENSSL_ROOT_DIR=C:\Program Files\OpenSSL" >> $GITHUB_OUTPUT
fi
- name: Determine root
id: determine-root
shell: bash
run: |
if [ ! -z "$ROOT_CHOCO" ]; then
echo "OPENSSL_ROOT_DIR=$ROOT_CHOCO" >> $GITHUB_OUTPUT
echo Setting OPENSSL_ROOT_DIR to "$ROOT_CHOCO"
elif [ ! -z "$ROOT_BREW" ]; then
echo "OPENSSL_ROOT_DIR=$ROOT_BREW" >> $GITHUB_OUTPUT
echo Setting OPENSSL_ROOT_DIR to "$ROOT_BREW"
fi
env:
ROOT_CHOCO: ${{ steps.choco-action.outputs.OPENSSL_ROOT_DIR }}
ROOT_BREW: ${{ steps.brew-action.outputs.OPENSSL_ROOT_DIR }}
45 changes: 45 additions & 0 deletions .github/workflows/hello-apps.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
name: hello-apps

on:
push:
branches: [ main ]
paths-ignore:
- '**.md' #Do not need to run CI for markdown changes.
pull_request:
branches: [ main, "feat/**" ]
paths-ignore:
- '**.md'


jobs:
smoketest:
strategy:
matrix:
os: [ "ubuntu-22.04", "macos-12", "windows-2022" ]
fail-fast: false
runs-on: ${{ matrix.os }}
steps:
- uses: actions/checkout@v3
- uses: ilammy/msvc-dev-cmd@v1
- name: Install Ninja
uses: ./.github/actions/install-ninja
- name: Install boost
uses: ./.github/actions/install-boost
id: install-boost
- name: Install OpenSSL
uses: ./.github/actions/install-openssl
id: install-openssl
- name: Statically Linked Hello Apps
shell: bash
run: ./scripts/run-hello-apps.sh static hello-c-client hello-cpp-client hello-c-server hello-cpp-server
env:
BOOST_ROOT: ${{ steps.install-boost.outputs.BOOST_ROOT }}
OPENSSL_ROOT_DIR: ${{ steps.install-openssl.outputs.OPENSSL_ROOT_DIR }}
- name: Dynamically Linked Hello Apps
shell: bash
continue-on-error: true # TODO(SC-223804)
# Only the C bindings work with dynamic linking because C++ symbols are hidden
run: ./scripts/run-hello-apps.sh dynamic hello-c-client hello-c-server
env:
BOOST_ROOT: ${{ steps.install-boost.outputs.BOOST_ROOT }}
OPENSSL_ROOT_DIR: ${{ steps.install-openssl.outputs.OPENSSL_ROOT_DIR }}
34 changes: 27 additions & 7 deletions examples/hello-c-client/main.c
Original file line number Diff line number Diff line change
Expand Up @@ -18,16 +18,20 @@
// the client to become initialized.
#define INIT_TIMEOUT_MILLISECONDS 3000

char const* get_with_env_fallback(char const* source_val,
char const* env_variable,
char const* error_msg);

int main() {
if (!strlen(MOBILE_KEY)) {
printf(
"*** Please edit main.c to set MOBILE_KEY to your LaunchDarkly "
"mobile key first\n\n");
return 1;
}
char const* mobile_key = get_with_env_fallback(
MOBILE_KEY, "LD_MOBILE_KEY",
"Please edit main.c to set MOBILE_KEY to your LaunchDarkly mobile key "
"first.\n\nAlternatively, set the LD_MOBILE_KEY environment "
"variable.\n"
"The value of MOBILE_KEY in main.c takes priority over LD_MOBILE_KEY.");

LDClientConfigBuilder config_builder =
LDClientConfigBuilder_New(MOBILE_KEY);
LDClientConfigBuilder_New(mobile_key);

LDClientConfig config = NULL;
LDStatus config_status =
Expand Down Expand Up @@ -76,3 +80,19 @@ int main() {

return 0;
}

char const* get_with_env_fallback(char const* source_val,
char const* env_variable,
char const* error_msg) {
if (strlen(source_val)) {
return source_val;
}

char const* from_env = getenv(env_variable);
if (from_env && strlen(from_env)) {
return from_env;
}

printf("*** %s\n\n", error_msg);
exit(1);
}
35 changes: 28 additions & 7 deletions examples/hello-c-server/main.c
Original file line number Diff line number Diff line change
Expand Up @@ -18,15 +18,20 @@
// the client to become initialized.
#define INIT_TIMEOUT_MILLISECONDS 3000

char const* get_with_env_fallback(char const* source_val,
char const* env_variable,
char const* error_msg);

int main() {
if (!strlen(SDK_KEY)) {
printf(
"*** Please edit main.c to set SDK_KEY to your LaunchDarkly "
"SDK key first\n\n");
return 1;
}
char const* sdk_key = get_with_env_fallback(
SDK_KEY, "LD_SDK_KEY",
"Please edit main.c to set SDK_KEY to your LaunchDarkly server-side "
"SDK key "
"first.\n\nAlternatively, set the LD_SDK_KEY environment "
"variable.\n"
"The value of SDK_KEY in main.c takes priority over LD_SDK_KEY.");

LDServerConfigBuilder config_builder = LDServerConfigBuilder_New(SDK_KEY);
LDServerConfigBuilder config_builder = LDServerConfigBuilder_New(sdk_key);

LDServerConfig config = NULL;
LDStatus config_status =
Expand Down Expand Up @@ -76,3 +81,19 @@ int main() {

return 0;
}

char const* get_with_env_fallback(char const* source_val,
char const* env_variable,
char const* error_msg) {
if (strlen(source_val)) {
return source_val;
}

char const* from_env = getenv(env_variable);
if (from_env && strlen(from_env)) {
return from_env;
}

printf("*** %s\n\n", error_msg);
exit(1);
}
34 changes: 27 additions & 7 deletions examples/hello-cpp-client/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -14,16 +14,20 @@
// the client to become initialized.
#define INIT_TIMEOUT_MILLISECONDS 3000

char const* get_with_env_fallback(char const* source_val,
char const* env_variable,
char const* error_msg);

using namespace launchdarkly;
int main() {
if (!strlen(MOBILE_KEY)) {
printf(
"*** Please edit main.cpp to set MOBILE_KEY to your LaunchDarkly "
"mobile key first\n\n");
return 1;
}
char const* mobile_key = get_with_env_fallback(
MOBILE_KEY, "LD_MOBILE_KEY",
"Please edit main.c to set MOBILE_KEY to your LaunchDarkly mobile key "
"first.\n\nAlternatively, set the LD_MOBILE_KEY environment "
"variable.\n"
"The value of MOBILE_KEY in main.c takes priority over LD_MOBILE_KEY.");

auto config = client_side::ConfigBuilder(MOBILE_KEY).Build();
auto config = client_side::ConfigBuilder(mobile_key).Build();
if (!config) {
std::cout << "error: config is invalid: " << config.error() << '\n';
return 1;
Expand Down Expand Up @@ -57,3 +61,19 @@ int main() {

return 0;
}

char const* get_with_env_fallback(char const* source_val,
char const* env_variable,
char const* error_msg) {
if (strlen(source_val)) {
return source_val;
}

char const* from_env = std::getenv(env_variable);
if (from_env && strlen(from_env)) {
return from_env;
}

std::cout << "*** " << error_msg << std::endl;
std::exit(1);
}
49 changes: 29 additions & 20 deletions examples/hello-cpp-server/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
#include <iostream>

// Set SDK_KEY to your LaunchDarkly SDK key.
#define SDK_KEY "foo"
#define SDK_KEY ""

// Set FEATURE_FLAG_KEY to the feature flag key you want to evaluate.
#define FEATURE_FLAG_KEY "my-boolean-flag"
Expand All @@ -15,29 +15,22 @@
// the client to become initialized.
#define INIT_TIMEOUT_MILLISECONDS 3000

char const* get_with_env_fallback(char const* source_val,
char const* env_variable,
char const* error_msg);
using namespace launchdarkly;
using namespace launchdarkly::server_side;

int main() {
if (!strlen(SDK_KEY)) {
printf(
"*** Please edit main.cpp to set SDK_KEY to your LaunchDarkly "
"SDK key first\n\n");
return 1;
}

auto cfg_builder = ConfigBuilder(SDK_KEY);

auto const streaming_connection =
DataSourceBuilder::Streaming().InitialReconnectDelay(
std::chrono::seconds(1));

auto system =
DataSystemBuilder::BackgroundSync().Synchronizer(streaming_connection);

cfg_builder.DataSystem().Method(system);

auto config = cfg_builder.Build();
char const* sdk_key = get_with_env_fallback(
SDK_KEY, "LD_SDK_KEY",
"Please edit main.c to set SDK_KEY to your LaunchDarkly server-side "
"SDK key "
"first.\n\nAlternatively, set the LD_SDK_KEY environment "
"variable.\n"
"The value of SDK_KEY in main.c takes priority over LD_SDK_KEY.");

auto config = ConfigBuilder(sdk_key).Build();
if (!config) {
std::cout << "error: config is invalid: " << config.error() << '\n';
return 1;
Expand Down Expand Up @@ -71,3 +64,19 @@ int main() {

return 0;
}

char const* get_with_env_fallback(char const* source_val,
char const* env_variable,
char const* error_msg) {
if (strlen(source_val)) {
return source_val;
}

char const* from_env = std::getenv(env_variable);
if (from_env && strlen(from_env)) {
return from_env;
}

std::cout << "*** " << error_msg << std::endl;
std::exit(1);
}
3 changes: 1 addition & 2 deletions release-please-config.json
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,7 @@
"CMakeLists.txt"
],
"prerelease": true,
"bump-minor-pre-major": true,
"release-as": "0.1.0"
"bump-minor-pre-major": true
},
"libs/server-sent-events": {
"initial-version": "0.1.0"
Expand Down
45 changes: 45 additions & 0 deletions scripts/run-hello-apps.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
#!/bin/bash
# This script builds a set of hello-app cmake targets
# using static or dynamic linkage.
# This script should be ran from the root directory of the project.
# Example:
# ./scripts/run-hello-apps.sh dynamic hello-cpp-client hello-c-client
#
# $1 is the linkage, either 'static' or 'dynamic'.
# Subsequent arguments are cmake target names.

if [ "$1" != "static" ] && [ "$1" != "dynamic" ]
then
echo "Linkage must be specified ('static' or 'dynamic')"
exit 1
fi

dynamic_linkage="Off"
if [ "$1" == "dynamic" ]; then
dynamic_linkage="On"
fi

shift

function cleanup {
cd ..
}

mkdir -p build-"$1"
cd build-"$1" || exit

# After we enter the directory we want to make sure we always exit it when the
# script ends.
trap cleanup EXIT

cmake -G Ninja -D CMAKE_BUILD_TYPE=Release -D BUILD_TESTING=OFF -D LD_BUILD_SHARED_LIBS=$dynamic_linkage ..

export LD_MOBILE_KEY="bogus"
export LD_SDK_KEY="bogus"

for target in "$@"
do
cmake --build . --target "$target"
./examples/"$target"/"$target" | tee "$target"_output.txt
grep "failed to initialize" "$target"_output.txt || (echo "$target: expected connection to LD to fail" && exit 1)
done

0 comments on commit 1676f67

Please sign in to comment.