mirror of
https://github.com/ossrs/srs.git
synced 2025-03-09 15:49:59 +00:00
Compare commits
9 commits
v3.0-r8
...
3.0release
Author | SHA1 | Date | |
---|---|---|---|
|
e801174ab2 | ||
|
b4220ee7c1 | ||
|
21be9daba4 | ||
|
9eadebdde7 | ||
|
2431e0b140 | ||
|
b3516b88dc | ||
|
1d79ef87a5 | ||
|
8d44b982ee | ||
|
b02c814251 |
10 changed files with 99 additions and 29 deletions
4
.github/workflows/release.yml
vendored
4
.github/workflows/release.yml
vendored
|
@ -7,7 +7,7 @@ on:
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
k8s:
|
k8s:
|
||||||
name: release-k8s
|
name: actions-release-k8s
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
|
@ -32,7 +32,7 @@ jobs:
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
echo "Release ossrs/srs:$SRS_TAG"
|
echo "Release ossrs/srs:$SRS_TAG"
|
||||||
docker build --tag ossrs/srs:$SRS_TAG trunk
|
docker build --tag ossrs/srs:$SRS_TAG -f trunk/Dockerfile .
|
||||||
|
|
||||||
- name: Login docker hub
|
- name: Login docker hub
|
||||||
uses: docker/login-action@v1
|
uses: docker/login-action@v1
|
||||||
|
|
47
.github/workflows/test.yml
vendored
Normal file
47
.github/workflows/test.yml
vendored
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
name: "Test"
|
||||||
|
|
||||||
|
on: [push, pull_request]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
utest:
|
||||||
|
name: actions-test-utest
|
||||||
|
runs-on: ubuntu-20.04
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
|
||||||
|
################################################################
|
||||||
|
# Tests
|
||||||
|
- name: Build test image
|
||||||
|
run: docker build --tag srs:test -f trunk/Dockerfile.test .
|
||||||
|
# For utest
|
||||||
|
- name: Run SRS utest
|
||||||
|
run: docker run --rm srs:test bash -c 'make && ./objs/srs_utest'
|
||||||
|
coverage:
|
||||||
|
name: actions-test-coverage
|
||||||
|
runs-on: ubuntu-20.04
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
|
||||||
|
################################################################
|
||||||
|
# Tests
|
||||||
|
- name: Build coverage image
|
||||||
|
run: docker build --tag srs:cov -f trunk/Dockerfile.cov .
|
||||||
|
# For coverage
|
||||||
|
- name: Run SRS covergae
|
||||||
|
if: ${{ startsWith(github.ref, 'refs/heads/') || startsWith(github.ref, 'refs/pull/') }}
|
||||||
|
run: |
|
||||||
|
# The hash of commit.
|
||||||
|
SRS_SHA=${{ github.sha }}
|
||||||
|
# Note that the root of SRS, must contains .git, for report fixing.
|
||||||
|
SRS_PROJECT=/srs
|
||||||
|
# The github.ref is, for example, refs/heads/3.0release
|
||||||
|
SRS_BRANCH=$(echo ${{ github.ref }}| awk -F 'refs/heads/' '{print $2}'| awk -F '/' '{print $1}')
|
||||||
|
# The github.ref is, for example, refs/pull/2536/merge
|
||||||
|
SRS_PR=$(echo ${{ github.ref }}| awk -F 'refs/pull/' '{print $2}'| awk -F '/' '{print $1}')
|
||||||
|
echo "For ref=${{ github.ref }}, sha=${{ github.sha }}, SRS_BRANCH=$SRS_BRANCH, SRS_PR=$SRS_PR, SRS_SHA=$SRS_SHA, SRS_PROJECT=$SRS_PROJECT"
|
||||||
|
docker run --rm --env SRS_BRANCH=$SRS_BRANCH --env SRS_PR=$SRS_PR --env SRS_SHA=$SRS_SHA --env SRS_PROJECT=$SRS_PROJECT \
|
||||||
|
srs:cov bash -c 'make && ./objs/srs_utest && bash auto/coverage.sh'
|
|
@ -1,7 +1,8 @@
|
||||||
# SRS(Simple Realtime Server)
|
# SRS(Simple Realtime Server)
|
||||||
|
|
||||||

|

|
||||||
[](https://circleci.com/gh/ossrs/srs/tree/3.0release)
|
[](https://github.com/ossrs/srs/actions?query=workflow%3ATest+branch%3A3.0release)
|
||||||
|
[](https://github.com/ossrs/srs/actions?query=workflow%3ARelease)
|
||||||
[](https://codecov.io/gh/ossrs/srs/branch/3.0release)
|
[](https://codecov.io/gh/ossrs/srs/branch/3.0release)
|
||||||
[](https://github.com/ossrs/srs/wiki/v1_CN_Contact#wechat)
|
[](https://github.com/ossrs/srs/wiki/v1_CN_Contact#wechat)
|
||||||
|
|
||||||
|
@ -129,6 +130,7 @@ Other important wiki:
|
||||||
|
|
||||||
## V3 changes
|
## V3 changes
|
||||||
|
|
||||||
|
* v3.0, 2021-10-08, Fix [#2606](https://github.com/ossrs/srs/issues/2606): Memory leak for RTMP client, pick from 4.0. v3.0.170
|
||||||
* <strong>v3.0, 2021-08-14, [3.0 release8(3.0.168)](https://github.com/ossrs/srs/releases/tag/v3.0-r8) released. 124469 lines.</strong>
|
* <strong>v3.0, 2021-08-14, [3.0 release8(3.0.168)](https://github.com/ossrs/srs/releases/tag/v3.0-r8) released. 124469 lines.</strong>
|
||||||
* <strong>v3.0, 2021-07-04, [3.0 release7(3.0.164)](https://github.com/ossrs/srs/releases/tag/v3.0-r7) released. 123463 lines.</strong>
|
* <strong>v3.0, 2021-07-04, [3.0 release7(3.0.164)](https://github.com/ossrs/srs/releases/tag/v3.0-r7) released. 123463 lines.</strong>
|
||||||
* v3.0, 2021-07-04, For [#2424](https://github.com/ossrs/srs/issues/2424), use srandom/random to generate. 3.0.164
|
* v3.0, 2021-07-04, For [#2424](https://github.com/ossrs/srs/issues/2424), use srandom/random to generate. 3.0.164
|
||||||
|
|
|
@ -4,8 +4,8 @@ FROM ossrs/srs:dev AS build
|
||||||
RUN yum install -y gcc make gcc-c++ patch unzip perl git
|
RUN yum install -y gcc make gcc-c++ patch unzip perl git
|
||||||
|
|
||||||
# Build and install SRS.
|
# Build and install SRS.
|
||||||
COPY . /trunk
|
COPY . /srs
|
||||||
WORKDIR /trunk
|
WORKDIR /srs/trunk
|
||||||
RUN ./configure --jobs=2 && make -j2 && make install
|
RUN ./configure --jobs=2 && make -j2 && make install
|
||||||
|
|
||||||
# All config files for SRS.
|
# All config files for SRS.
|
||||||
|
@ -23,8 +23,8 @@ RUN cp -R research/players /usr/local/srs/objs/nginx/html/
|
||||||
############################################################
|
############################################################
|
||||||
FROM centos:7 AS dist
|
FROM centos:7 AS dist
|
||||||
|
|
||||||
# Expose ports for streaming @see https://github.com/ossrs/srs#ports
|
# Expose ports for live streaming
|
||||||
EXPOSE 1935 1985 8080 8000/udp 10080/udp
|
EXPOSE 1935 1985 8080
|
||||||
|
|
||||||
# FFMPEG 4.1
|
# FFMPEG 4.1
|
||||||
COPY --from=build /usr/local/bin/ffmpeg /usr/local/srs/objs/ffmpeg/bin/ffmpeg
|
COPY --from=build /usr/local/bin/ffmpeg /usr/local/srs/objs/ffmpeg/bin/ffmpeg
|
||||||
|
|
9
trunk/Dockerfile.cov
Normal file
9
trunk/Dockerfile.cov
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
FROM ossrs/srs:dev
|
||||||
|
|
||||||
|
# Install depends tools.
|
||||||
|
RUN yum install -y gcc make gcc-c++ patch unzip perl git
|
||||||
|
|
||||||
|
# Build and install SRS.
|
||||||
|
COPY . /srs
|
||||||
|
WORKDIR /srs/trunk
|
||||||
|
RUN ./configure --with-utest --gcov --jobs=2 && make -j2
|
9
trunk/Dockerfile.test
Normal file
9
trunk/Dockerfile.test
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
FROM ossrs/srs:dev
|
||||||
|
|
||||||
|
# Install depends tools.
|
||||||
|
RUN yum install -y gcc make gcc-c++ patch unzip perl git
|
||||||
|
|
||||||
|
# Build and install SRS.
|
||||||
|
COPY . /srs
|
||||||
|
WORKDIR /srs/trunk
|
||||||
|
RUN ./configure --with-utest --jobs=2 && make -j2
|
|
@ -1,36 +1,35 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# In .circleci/config.yml, generate *.gcno with
|
# In .circleci/config.yml, generate *.gcno with
|
||||||
# ./configure --gcov --without-research --without-librtmp && make
|
# ./configure --gcov --with-utest --without-research --without-librtmp && make
|
||||||
# and generate *.gcda by
|
# and generate *.gcda by
|
||||||
# ./objs/srs_utest
|
# ./objs/srs_utest
|
||||||
|
|
||||||
# Workdir is objs/cover.
|
# Workdir is objs/cover.
|
||||||
workdir=`pwd`/objs/cover
|
workdir=`pwd`/objs/cover
|
||||||
|
|
||||||
# Tool git is required to map the right path.
|
|
||||||
git --version >/dev/null 2>&1
|
|
||||||
ret=$?; if [[ $ret -ne 0 ]]; then echo "Tool git is required, ret=$ret"; exit $ret; fi
|
|
||||||
|
|
||||||
# Create trunk under workdir.
|
# Create trunk under workdir.
|
||||||
mkdir -p $workdir && cd $workdir
|
mkdir -p $workdir && cd $workdir
|
||||||
ret=$?; if [[ $ret -ne 0 ]]; then echo "Enter workdir failed, ret=$ret"; exit $ret; fi
|
ret=$?; if [[ $ret -ne 0 ]]; then echo "Enter workdir failed, ret=$ret"; exit $ret; fi
|
||||||
|
|
||||||
# Collect all *.gcno and *.gcda to objs/cover.
|
CODECOV_ARGS=""
|
||||||
cd $workdir && (rm -rf src && cp -R ../../src . && cp -R ../src/* src/)
|
if [[ $SRS_PROJECT != '' ]]; then
|
||||||
ret=$?; if [[ $ret -ne 0 ]]; then echo "Collect *.gcno and *.gcda failed, ret=$ret"; exit $ret; fi
|
# -R root dir Used when not in git/hg project to identify project root directory
|
||||||
|
# -p dir Project root directory. Also used when preparing gcov
|
||||||
# Generate *.gcov for coverage.
|
CODECOV_ARGS="$CODECOV_ARGS -R $SRS_PROJECT -p $SRS_PROJECT"
|
||||||
cd $workdir &&
|
fi
|
||||||
for file in `find src -name "*.cpp"|grep -v utest`; do
|
if [[ $SRS_BRANCH != '' ]]; then
|
||||||
gcov $file -o `dirname $file`
|
# -B branch Specify the branch name
|
||||||
ret=$?; if [[ $ret -ne 0 ]]; then echo "Collect $file failed, ret=$ret"; exit $ret; fi
|
CODECOV_ARGS="$CODECOV_ARGS -B $SRS_BRANCH"
|
||||||
done
|
fi
|
||||||
|
if [[ $SRS_SHA != '' ]]; then
|
||||||
# Cook the gcov files.
|
# -C sha Specify the commit sha
|
||||||
cd $workdir &&
|
CODECOV_ARGS="$CODECOV_ARGS -C $SRS_SHA"
|
||||||
find . -name "*.gcov"|grep -v srs|xargs rm -f
|
fi
|
||||||
ret=$?; if [[ $ret -ne 0 ]]; then echo "Cook gcov files failed, ret=$ret"; exit $ret; fi
|
if [[ $SRS_PR != '' ]]; then
|
||||||
|
# -P pr Specify the pull request number
|
||||||
|
CODECOV_ARGS="$CODECOV_ARGS -P $SRS_PR"
|
||||||
|
fi
|
||||||
|
|
||||||
# Upload report with *.gcov
|
# Upload report with *.gcov
|
||||||
# Remark: The file codecov.yml is not neccessary. It literally depends on git.
|
# Remark: The file codecov.yml is not neccessary. It literally depends on git.
|
||||||
|
@ -41,5 +40,6 @@ ret=$?; if [[ $ret -ne 0 ]]; then echo "Cook gcov files failed, ret=$ret"; exit
|
||||||
# https://circleci.com/gh/ossrs/srs/tree/3.0release
|
# https://circleci.com/gh/ossrs/srs/tree/3.0release
|
||||||
cd $workdir &&
|
cd $workdir &&
|
||||||
export CODECOV_TOKEN="493bba46-c468-4e73-8b45-8cdd8ff62d96" &&
|
export CODECOV_TOKEN="493bba46-c468-4e73-8b45-8cdd8ff62d96" &&
|
||||||
bash <(curl -s https://codecov.io/bash) &&
|
bash <(curl -s https://codecov.io/bash) $CODECOV_ARGS &&
|
||||||
echo "Done" && exit 0
|
echo "Done" && exit 0
|
||||||
|
|
||||||
|
|
|
@ -44,6 +44,8 @@ extern bool _srs_in_docker;
|
||||||
|
|
||||||
void srs_build_features(stringstream& ss)
|
void srs_build_features(stringstream& ss)
|
||||||
{
|
{
|
||||||
|
ss << "&os=linux";
|
||||||
|
|
||||||
ss << "&docker=" << _srs_in_docker
|
ss << "&docker=" << _srs_in_docker
|
||||||
<< "&packager=" << SRS_AUTO_PACKAGER;
|
<< "&packager=" << SRS_AUTO_PACKAGER;
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,6 +24,6 @@
|
||||||
#ifndef SRS_CORE_VERSION3_HPP
|
#ifndef SRS_CORE_VERSION3_HPP
|
||||||
#define SRS_CORE_VERSION3_HPP
|
#define SRS_CORE_VERSION3_HPP
|
||||||
|
|
||||||
#define SRS_VERSION3_REVISION 168
|
#define SRS_VERSION3_REVISION 170
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -57,6 +57,7 @@ SrsBasicRtmpClient::~SrsBasicRtmpClient()
|
||||||
close();
|
close();
|
||||||
srs_freep(kbps);
|
srs_freep(kbps);
|
||||||
srs_freep(clk);
|
srs_freep(clk);
|
||||||
|
srs_freep(req);
|
||||||
}
|
}
|
||||||
|
|
||||||
srs_error_t SrsBasicRtmpClient::connect()
|
srs_error_t SrsBasicRtmpClient::connect()
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue